Awesome
Lw
Lw is a general-purpose statically-typed functional-first language aimed at writing succinct, robust, powerful and highly reusable code. It includes some of the most advanced achievements in language literature as well as several novel features. Lw is currently in development and its implementation could still be unstable, nonetheless it has reached a stage at which people who enjoy experimenting with new programming languages may want to play with it.
I will keep this README file updated and increasingly document the language as development goes on. Consider, however, that features may change in the future or may get broken at some point until a stable version or an hotfix is released.
Installation
Lw and the Lw Interpreter are written in F#, therefore you probably want to import the solution into Visual Studio in order to compile it and play with its interactive console. Assuming you are using at least VS2013 - though VS2015 Community edition is the one I'm developing with at the moment - you should encounter no troubles in making NuGet package manager automatically download dependencies and get the solution compile.
VS Solution and Dependencies
Lw.sln consists of 3 projects:
- Core. The core of the language: lexer, parser and type checker plus all that is related to them. This is a library project and cannot be run.
- Interpreter. This is the real Lw interpreter and it's a startup*-able* project generating an executable.
- FSharp.Common. This is another library project which both Core and Interpreter projects rely on. It is distributed separately as a stand-alone GitHub project of mine.
Usage
The Lw interpreter can be used in a few ways:
- passing a source file name as argument to the executable: this makes the interpreter evaluate the whole program and return an interger exit code.
- launching the executable with the
--interactive
command line argument: this runs the interpreter in interactive mode, pretty much like other functional languages interactive console. You can write declarations and expressions and see the type inferred as well as the result of the evaluation. - mixing the two ways above: this makes the interpreter evaluate the source input file and eventually open the interactive console with an environment populated with all the stuff defined at top level in the input file.
Visual Studio users may activate the "Interactive" solution configuration on the left of the play button and launch the interpreter in interactive mode.
Language specification
Please read the Lw spec document for further details.