Spiritually dialect of ClojureScript. Built with Rust. Also compiles to JavaScript ES Modules.
Browse examples or also try WASM version online.
Core design:
Build and install with Rust:
```bash
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
cargo install calcit ```
For Ubuntu latest, try binaries from http://bin.calcit-lang.org/linux/ , which are provided for CI usages.
Snippets evaling:
bash
cr -e 'range 100'
multi-lines snippet:
```bash cr -e '
println "|a demo"
-> range 100 map $ fn (x) * x x
' ```
Run with a compact.cirru:
```bash cr compact.cirru -1 # run only once
cr compact.cirru # watch mode enabled by default
cr compact.cirru --init-fn='app.main/main!' # specifying init-fn ```
It compiles to JavaScript and runs in consistet semantics. However it might require a lot of JavaScript interop.
bash
cr compact.cirru --emit-js # compile to js
cr compact.cirru --emit-js --emit-path=out/ # compile to js and save in `out/`
By default, js code is generated to js-out/
. You will need Vite or Esbuild to run it, from an entry file:
js
import { main_$x_, reload_$x_ } from "./js-out/app.main.js";
main_$x_();
Install Calcit Editor and run ct
to launch editor server,
which writes compact.cirru
and .compact-inc.cirru
on saving. Try launching example by cloning Calcit Workflow.
Read more in Minimal Calcit to learn how to code Calcit with a plain text editor.
Read more in Respo Calcit Workflow to learn to create an MVC webpage with Respo.
No package manager yet, need to manage modules with git tags.
Configurations inside calcit.cirru
and compact.cirru
:
cirru
:configs $ {}
:modules $ [] |memof/compact.cirru |lilac/
Paths defined in :modules
field are just loaded as files from ~/.config/calcit/modules/
,
i.e. ~/.config/calcit/modules/memof/compact.cirru
.
Modules that ends with /
s are automatically suffixed compact.cirru
since it's the default filename.
To load modules in CI environments, make use of git clone
.
I use these commands to run local examples:
```bash
cargo run --bin cr -- calcit/test.cirru -1
cargo run --bin cr -- calcit/test.cirru --emit-js -1 && yarn try-js
cargo run --bin cr -- -e 'range 100'
cr compact.cirru --emit-ir # compiles intermediate representation into program-ir.cirru ```
compact.cirru
file parsing.Other tools:
.calcit-error.cirru
program-ir.cirru
Some resources:
MIT