mirror of
https://github.com/leafo/moonscript.git
synced 2025-01-09 00:04:22 +00:00
cleanup readme for site
This commit is contained in:
parent
2fbbef9c44
commit
0d41436951
144
README.md
144
README.md
@ -4,150 +4,8 @@ MoonScript is a programmer friendly language that compiles into
|
|||||||
[Lua](http://ww.lua.org/). It gives you the power of the fastest scripting
|
[Lua](http://ww.lua.org/). It gives you the power of the fastest scripting
|
||||||
language combined with a rich set of features:
|
language combined with a rich set of features:
|
||||||
|
|
||||||
* Provides a clean syntax using significant whitespace that avoids all the
|
See <http://moonscript.org>.
|
||||||
keyword noise typically seen in a Lua script.
|
|
||||||
|
|
||||||
* Adds table comprehensions, implicit return on functions, classes,
|
|
||||||
inheritance, scope management statements `import` & `export`, and a
|
|
||||||
convenient object creation statement called `with`.
|
|
||||||
|
|
||||||
* Can be loaded directly from a Lua script without an intermediate compile
|
|
||||||
step. It even knows how to tell you where errors occurred in the original
|
|
||||||
file when they happen.
|
|
||||||
|
|
||||||
Creating an instance of a class and calling a method:
|
|
||||||
|
|
||||||
class Thing
|
|
||||||
name: "unknown"
|
|
||||||
|
|
||||||
class Person extends Thing
|
|
||||||
say_name: -> print "Hello, I am", @name
|
|
||||||
|
|
||||||
with Person!
|
|
||||||
.name = "Moonscript"
|
|
||||||
\say_name!
|
|
||||||
|
|
||||||
MoonScript can either be compiled into Lua and run at a later time, or it
|
|
||||||
can be dynamically compiled and run using the *moonloader*. It's as simple
|
|
||||||
`require "moon"` in order to have Lua understand how to load and run any
|
|
||||||
MoonScript file.
|
|
||||||
|
|
||||||
The command line tools also let you run MoonScript directly from the
|
|
||||||
command line, like any first-class scripting language.
|
|
||||||
|
|
||||||
## Installation
|
|
||||||
|
|
||||||
### Installing with LuaRocks
|
|
||||||
|
|
||||||
The easiest way to install is to use Lua rocks and the provide rockspec.
|
|
||||||
|
|
||||||
LuaRocks can be obtained [here](http://www.luarocks.org/) or from your package
|
|
||||||
manager.
|
|
||||||
|
|
||||||
After it is installed, run the following in a terminal:
|
|
||||||
|
|
||||||
~> wget https://raw.github.com/leafo/moonscript/master/moonscript-dev-1.rockspec
|
|
||||||
~> luarocks install moonscript-dev-1.rockspec
|
|
||||||
|
|
||||||
This will provide the `moon` and `moonc` tools along with the `moonscript`
|
|
||||||
Lua module.
|
|
||||||
|
|
||||||
### Optional
|
|
||||||
|
|
||||||
If you are on Linux and want to run *watch* mode, which compiles `.moon` files to
|
|
||||||
`.lua` files as they are changed, you can install
|
|
||||||
[linotify](https://github.com/hoelzro/linotify).
|
|
||||||
|
|
||||||
|
|
||||||
## Learning
|
|
||||||
|
|
||||||
Read the [reference manual](docs/index.md).
|
|
||||||
|
|
||||||
## Command Line Use
|
|
||||||
|
|
||||||
Two tools are installed with MoonScript, `moon` and `moonc`.
|
|
||||||
`moonc` is used for transforming MoonsScript code into a Lua file.
|
|
||||||
It takes a list of files, compiles them all, and creates the associated `.lua`
|
|
||||||
files in the same directories.
|
|
||||||
|
|
||||||
|
|
||||||
### moon
|
|
||||||
|
|
||||||
`moon` can be used to run MoonsScript files directly from the command line,
|
|
||||||
without needing a separate compile step. All MoonsScript files are compiled in
|
|
||||||
memory as they are run.
|
|
||||||
|
|
||||||
~> moon my_script.moon
|
|
||||||
|
|
||||||
Any MoonScript files that are required will also be compiled and run
|
|
||||||
automatically.
|
|
||||||
|
|
||||||
When an error occurs during runtime, the stack trace is rewritten to give line
|
|
||||||
numbers from the original `.moon` file.
|
|
||||||
|
|
||||||
If you want to disable error rewriting, you can pass the `-d` flag. A full list
|
|
||||||
of flags can be seen by passing the `-h` or `--help` flag.
|
|
||||||
|
|
||||||
|
|
||||||
### moonc
|
|
||||||
|
|
||||||
`moonc` is used for transforming a MoonsScript file into a Lua file.
|
|
||||||
It takes a list of files, compiles them all, and creates the associated `.lua`
|
|
||||||
files alongside the `.moon` files.
|
|
||||||
|
|
||||||
~> moonc my_script1.moon my_script2.moon ...
|
|
||||||
|
|
||||||
You can control where the compiled files are put using the `-t` flag, followed
|
|
||||||
by a directory.
|
|
||||||
|
|
||||||
`moonc` can also take a directory as an argument, and it will recursively scan
|
|
||||||
for all MoonScript files and compile them.
|
|
||||||
|
|
||||||
Combined with `linotify` on linux, the `-w` flag can be used to watch all files
|
|
||||||
that match the given search path for changes, and then compile them only when
|
|
||||||
required.
|
|
||||||
|
|
||||||
A full list of flags can be seen by passing the `-h` or `--help` flag.
|
|
||||||
|
|
||||||
## Overview of Differences & Highlights
|
|
||||||
|
|
||||||
A more detailed overview of the syntax can be found in the
|
|
||||||
[documentation](docs/index.md).
|
|
||||||
|
|
||||||
* Whitespace sensitive blocks defined by indenting
|
|
||||||
* All variable declarations are local by default
|
|
||||||
* `export` keyword to declare global variables, `import` keyword to make local
|
|
||||||
copies of values from a table
|
|
||||||
* Parentheses are optional for function calls, similar to Ruby
|
|
||||||
* Fat arrow, `=>`, can be used to create a function with a self argument
|
|
||||||
* `@` can be prefixed in front of a name to refer to that name in `self`
|
|
||||||
* `!` operator can be used to call a function with no arguments
|
|
||||||
* Implicit return on functions based on the type of last statement
|
|
||||||
* ':' is used to separate key and value in table literals instead of `=`
|
|
||||||
* Newlines can be used as table literal entry delimiters in addition to `,`
|
|
||||||
* `\` is used to call a method on an object instead of `:`
|
|
||||||
* `+=`, `-=`, `/=`, `*=`, `%=` operators
|
|
||||||
* `!=` is an alias for `~=`
|
|
||||||
* Table comprehensions, with convenient slicing and iterator syntax
|
|
||||||
* Lines can be decorated with for loops and if statements at the end of the line
|
|
||||||
* If statements can be used as expressions
|
|
||||||
* Class system with inheritance based on metatable's `__index` property
|
|
||||||
* Constructor arguments can begin with `@` to cause them to automatically be
|
|
||||||
assigned to the object
|
|
||||||
* Magic `super` function which maps to super class method of same name in a
|
|
||||||
class method
|
|
||||||
* `with` statement lets you access anonymous object with short syntax
|
|
||||||
|
|
||||||
|
|
||||||
## Dependencies
|
|
||||||
|
|
||||||
The following are used in MoonScript:
|
|
||||||
|
|
||||||
* [Lua 5.1](http://lua.org)
|
|
||||||
* [LPeg](http://www.inf.puc-rio.br/~roberto/lpeg/lpeg.html)
|
|
||||||
* [LuaFileSystem](http://keplerproject.github.com/luafilesystem/)
|
|
||||||
* [alt-getopt](http://luaforge.net/projects/alt-getopt/)
|
|
||||||
* and optionally on Linux [linotify](https://github.com/hoelzro/linotify)
|
|
||||||
|
|
||||||
## License (MIT)
|
## License (MIT)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user