mca-compiler v0.2.0
MCA Compiler
MCA is an assembly language that compiles to Minecraft circuitry, specifically Command Blocks. To simplify this, it also introduces a higher-level macro-based language that includes compile-time variables, functions, and operations.
This repository contains the MCA parser and compiler, which compiles to an intermediatery language named MCIL, as well as a set of command-line tools for compiling and debugging.
Documentation on the MCA language is contained in the wiki.
Installation
The compiler is availabe from NPM.
Install for command-line usage:
$ npm install mca-compiler -gInstall for Node-based usage:
$ npm install mca-compiler --saveCommand-line Usage
The compiler provides two commands to facilitate with parsing, compilation, and debugging.
Parsing
The mca-parse command parses code and provides an abstract syntax tree (AST) in various formats.
Usage:
mca-parse [file] [-h] [--help] [-s] [--show] [-f] [--friendly]
          [-c <input>] [--code <input>] [-o <file>] [--output< file>]mca-parse takes MCA code from --code (-c for short), [file] (a file path), or stdin (in that order), and parses it. If the --show (or -s) flag is set, the AST JSON will be sent to stdout. If the --output (or -o) flag is set, it will be written to the provided file, relative to the current directory.
The --friendly (or -f) flag formats the output of --show to be human-friendly, and aid debugging. It is represented in an XML-like tree view with the line positions of each node shown on the left.
Note: setting the --friendly flag will not affect what --output writes to the file. To write the friendly output to a file, use a pipe (e.g. with bash, mca-parse somefile.mca --friendly > friendly_ast).
Compiling
The mca-compile command inputs an abstract syntax tree, and provides information on the execution of the code, as well as the compiled commands.
Usage:
mca-compile [ast] [-h] [--help] [-t] [--tree] [-r] [--result] [-c] [--compiled]
            [-f] [--friendly] [-l] [--log] [-o <file>] [--output <file>]mca-compile takes a JSON-formatted AST from [ast] (a file path), or stdin (in that order), and executes it.
This command has various flags which enable different types of output. The --tree flag (-t for short) outputs a tree similar to an AST, but one that represents the order of execution of each node. The --result flag (-r for short) outputs the results from root-level expressions as JSON. The --compiled flag (-c for short) outputs the compiled MCIL as JSON.
If multiple outputs are enabled, they are outputted in the following order, separated by a new line:
- --tree
- --result
- --compiled
The --friendly flag, or -f for short, enables a human-friendly formatting for each output. For the execution tree, this is an XML-like output similar to --friendly for the mca-parse command. For the result flag, this is formatted JSON (with colours). For the compiled flag, this is a list of branches and instructions in a simple format.
The --log (or -l) flag enables output from the program through the .log internal function. This is displayed before all other outputs, and each line is prepended with [output]␣ (where ␣ is a trailing space) when the --friendly flag is not present.
The --output flag, or -o for short, is similar to mca-parse's output flag. It writes the compiled MCIL code (with no --friendly formatting) to the provided file, relative to the current directory.
All together, now
Both commands allow reading/writing from stdin and stdout respectively. This means that a file can be read, parsed, and compiled in one "command", such as the bash command, which will display the compiled MCIL in "friendly" mode:
mca-parse somefile.mca -s | mca-compile -c -fAlternatively, offloading file reading to cat:
cat somefile.mca | mca-parse -s | mca-compile -c -fRoadmap
The language and compiler roadmap is available in the ROADMAP file.
License
The MCA compiler is licensed under the MIT license. More information is available in the LICENSE file.
Toxic Spanner is not affiliated with Minecraft, Mojang, or Microsoft.