Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/qoh/lever


https://github.com/qoh/lever

Last synced: about 2 months ago
JSON representation

Awesome Lists containing this project

README

        

# Lever

Lever is a tool designed to make Blockland development better. It consists of three things:

* The original Lever - a transpiler that generates TorqueScript from a nicer language,
* liblever, a TorqueScript support library enabling the additional features of the Lever syntax, and
* A CLI for leveraging the Lever transpiler, which also integrates some tools to streamline development.

## Getting Set Up

1. Install [NodeJS](https://nodejs.org).
2. Get the code - Clone this repository or use the Download ZIP button above.
3. Install the package:
Extract the ZIP if necessary, then call `npm install -g` from the lever directory. You will probably need administrative privileges to do this (Right click cmd -> Launch as Administrator, or `sudo`)

### Basic Usage

`lever [command] [args]`

Global switches:

* -s, --silent: Suppress all non-erroneous console output.
* -h, --help: Get help with the given command. (unimplemented)

Commands:

* `compile`: Compile a given set of files. If no valid command is supplied, defaults to this.
* `-c, --compact`: Omit all unnecessary whitespace.
* `-p, --profile`: Inject `PROFILER_ENTER` and `PROFILER_LEAVE` calls into functions.
* `-o, --out`: Write all output to the given file instead of individual files.
* `init | new`: Create a skeleton for a new add-on. (unimplemented)
* `-t, --title`: Pre-supply a title for the add-on. Defaults to the current working directory's name.
* `-a, --author`: Pre-supply an author for the add-on. Defaults to the USERNAME environment variable.
* `-d, --desc`: Pre-supply a description for the add-on.
* `build | package`: Package the current project into an Add-On. (unimplemented)
* `-c, --compact`: As with compile.
* `-o, --out`: Output to the given file instead of the default zip.

## Syntax

*NOTE: This guide is for people who already understand how to program. Please do not attempt to use this guide as a means to begin learning programming, it will not work.*

### Basic Syntax

Local variables do not have `%` prepended to them - they are plain. `client` is the same as `%client` in raw TorqueScript. Lever also uses the same standard operands as TorqueScript - including the Torque-specific string catenation operands `@` `SPC` `TAB` and `NL`. Names such as objects or datablocks should either be wrapped in a string or written as `@name`–otherwise they would be confused with local variables. If you need further examples of how to use a part of Lever, please refer to the tests folder.

### Functions

Functions are pretty much the same in Lever as they are in TorqueScript, aside from a few minor oddities. For instance, functions are declared using `fn` instead of `function`. Also, the following are equivalent:

fn myFunc {
echo("Hello world!");
}

fn myFunc() {
echo("Hello world!");
}

Arguments are supplied much the same as in normal TorqueScript:

fn myFunc(a, b) {
echo(a @ " " @ b @ "!");
}

Lever also supports default arguments:

fn myFunc(a, b="world") {
echo(a @ " " @ b @ "!");
}

Note that these are evaluated as expressions in the function body, so using the previous arguments or creating objects will work fine.

Lever also supports anonymous functions:

schedule(1000, 0, fn(a) {
echo(a);
}, "Hello world!");

### Packages

package MyPackage {

};

Prepending `active` will activate the package by default:

active package MyPackage {

};

Parenting is done by simply calling `Parent` regardless of the function:

active package MyPackage {
fn myFunc(a, b) {
Parent("Hello", "world");
}
};

### Classes

Lever has closer to first-class support for Classes:

class Foo {
author = "RoboCop";

fn onNew(n) {
this.n = n;
}

fn inc {
this.n++;
}
}

x = Foo();
x.inc();

Lever also supports static classes, initiated with the `static` keyword. These classes are for singletons - they cannot be renamed or deleted.

static class GameManager {
key = "value";

fn reset() {
for client in ClientGroup.iter() {
client.instantRespawn();
}
}
}

Lever also supports inheritance.

class Foo {
fn firstTest(foo, bar) {}
fn secondTest(spam) {}
}

class Bar : Foo {
fn firstTest(foo, bar) {}
fn thirdTest() {}
}

### Fenced TorqueScript Code

If you need to just write some raw TorqueScript, you can do so:

for i in 0..mg.numMembers {
`%mb = %mg.member[%i]`;
messageClient(mb, '', "nope");
}

### Datablocks

Datablocks are created very similarly to the way they are normally created in TorqueScript, except adapted to fit the mindset of Lever. The following is valid Lever (but won't work in TorqueScript):

datablock ShapeBaseImage weaponImage {
colors: ["1 2 3", "4 5 6"],

state Test {
example: "Hi",
also: 1.23
},

state OtherTest {
example: "Oh hi again",
again: 1.513
}
}

The `colors` array will be expanded to `colors[0]` and `colors[1]` and there will be states appropriately created for both `Test` and `OtherTest`. Please refer to datablock.ls for an example of the Weapon_Sword implemented in Lever.

## API

Lever supports a robust API through NodeJS:

`require("lever")(source, options)`

Current options:

* compact: Remove unnecessary whitespace. Defaults to false (pass switch `-c` or `--compact`).

//TODO: Improve API.