CLI for the Gobstones interpreter
# requires node > 6
sudo npm install -g gobstones-cli
npm test
The cli can be wrapped as an executable using nexe: npm install nexe -g
.
git clone https://github.com/gobstones/gobstones-cli
cd gobstones-cli
nexe -i src/index.js -o gobstones-cli
gobstones-cli --help
echo "program {\n Poner(Rojo)\n }" > /tmp/gobs.gbs
gobstones-cli /tmp/gobs.gbs -f gbb
See the tests for more examples!
batch.json
:
{
"code": "procedure Meter(color) { Poner(color) }", // Student's code
"extraCode": "function a() { return (2) }", // [OPTIONAL] Teacher's code
"examples": [
{
"initialBoard": "GBB/1.0\nsize 4 4\nhead 0 0", // Initial board
"extraBoard": "GBB/1.0\nsize 4 4\nhead 0 0", // [OPTIONAL] Expected board
"generatedCode": "procedure Meter(color) { Poner(color) } program { Meter(Azul) }" // [OPTIONAL] Code to be executed, overrides `code`
},
{
"initialBoard": "GBB/1.0\nsize 4 4\nhead 0 0",
"extraBoard": "GBB/1.0\nsize 4 4\nhead 0 0",
"generatedCode": "program { Poner(Rojo) Poner(Verde) Poner(Negro) }"
}
]
}
gobstones-cli --batch batch.json
# returns an array with the responses
This tool can also generate the AST of a Gobstones program, in two different fashions:
- native AST - that is, the AST internally used by the tool to execute programs
- mulang AST - a simple AST suited to perform code analysys, that can be processed by the Mulang tool
echo "program { Poner(Azul) }" | gobstones-cli --ast --from_stdin
{
"alias": "program",
"body": [
{
"arity": "statement",
"alias": "Drop",
"parameters": [
{
"value": 0,
"alias": "Blue"
}
]
}
]
}
echo "program { Poner(Azul) }" | gobstones-cli --mulang_ast --from_stdin | json_pp
{
"tag" : "EntryPoint",
"contents" : [
"program",
{
"tag" : "Application",
"contents" : [
{
"tag" : "Reference",
"contents" : "Poner"
},
[
{
"tag" : "MuSymbol",
"contents" : "Azul"
}
]
]
}
]
}