Brim is an optimizing brain* interpreter than nonetheless strives to be very pleasant and easy to use.
Brim uses a wrapping 30000-cell tape, with a single wrapping signed byte in each cell.
If compiled in debug mode, or with the feature flag debug
, brim will
recognize the character ;
, and will dump several relevant bits of info
(the tape, the tape pointer, and three instructions for context) to
output.
With the -i | --input
and -o | --output
flags, brim can read/write to/from
files instead of stdin/stdout.
Regardless of source or destination, all I/O is buffered to provide a fast and reliable experience (the output is flushed on each newline, and upon exit).
Brim internally uses a token-based intermediary structure to execute the code. First, it groups together add, subtract, left, and right instructions to save needless cycles (as well as discards redundant instructions).
Then, it performs several macro-optimizations to reduce common operations to a single "instruction". Currently, it recognizes:
[-]
)[-]++++
)[->+<]
/ [>+<-]
)The token-based structure makes these trivial to recognize, since repeating instructions have already been collapsed into one.
Finally, it iterates over each bracket ([
/]
) and pre-loads its destination,
so executing them requires zero lookup time (it just overrides the IP).
These are all run in a buffered I/O environment, as detailed above.
Brim isn't finished yet! My hopes for the future include:
Contributions are always welcome, especially optimizations! Please, before you
create a pull request, run cargo fmt
and cargo clippy
.
If you want to implement a new feature, consider gating it behind a feature flag. This can reduce code size as well as slightly improve runtimes. It isn't appropriate for all, but it is worth considering.