#language #automation #interpreter #dsl #make #variables

build instruct

A language to write general purpose 'makefile like' tasks which are powerful and reuseable

1 unstable release

0.1.0 May 28, 2022

#525 in Build Utils

MIT license

84KB
2K SLoC

Instruct

codecov

A language to write general purpose 'makefile like' tasks which are powerful and reuseable.

Status

This project is somewhat working!

  • Parsing
    • []
  • Static analysis
  • Interpreter
  • Task project definition and config files
  • [] Dependency system
  • [] Runner system
    • cmd's
    • [] ssh
    • [] docker
    • [] python
  • [] Testing system

Goals

My goal for this project is to provide an alternative to makefiles / bash scripts, especially for the devops world.
Most of the time automation code is simply dumped into a few bash scripts or directly into pipeline config files, which makes them hard to maintain / reuse.

Therefor this language thrives to provide following goals:

  • Clean syntax that is easy to read and understand
  • Reuseability of tasks
  • Simple package / dependency system
  • Native support for multiple executors:
    • Simple shell
    • Docker
    • Python

Example

A currently fully working small example.

module as variables;

collection as interpolate: {
    let (final_stdout: stdout) from task as stdout: {
        let (pre_var: var) from block as pre: {
            let (var: stdout) from run with (trim_stdout): echo pre;
            run: echo dyn_${var};
        };
        let (stdout) from run with (trim_stdout) as main: echo interpolated '${pre_var}' used in main;
        block as post: {
            let (stdout) from run with (stdin: stdout): sed s/main/post/g;
            run: echo ${stdout};
        };
    };

    task as call: {
        let (final_stdout) from call as main: variables.interpolate.stdout;
        run as post: echo ${final_stdout} used after call;
    };

    task as exit-code: {
        let (status1: status) from run as pre: cat Cargo.toml;
        let (status2: status) from run as main: cat random_file.json;
        run as post: echo "cat Cargo.toml: $${status1}, cat random_file.json: $${status2}";
    };
};

It can be executed using cargo:

cargo run variables.interpolate.stdout
cargo run variables.interpolate.exit-code

Dependencies

~7–15MB
~195K SLoC