# A CPP Implementation of Autumn that compiles to WASM (and more)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)

This repository hosts the Autumn interpreter, built with C++. It's usable in WebAssembly (`WASM`), `C++`, `Python` and `Julia`.

## Setting Up the Environment
Create a Conda environment using the following command:
```sh
conda env create --file environment.yml
```

## Building the C++ Interpreter
### Install Julia Package
Run julia and install CxxWrap
```sh
using Pkg
Pkg.add("CxxWrap")
```


Compile the C++ interpreter by running:
```sh
mkdir build && cd build
cmake .. -DCMAKE_PREFIX_PATH=$(julia -e 'using CxxWrap;print(joinpath(CxxWrap.prefix_path()), "/lib/cmake")')
make  -j12
cd ..
```

If you’re using macOS with Apple Silicon, use `cmake .. -DCMAKE_OSX_ARCHITECTURES=arm64` in place of `cmake ..` to ensures that all files are compiled and linked for arm64 architecture.

## Running Autumn programs

Then, in the same folder, execute the following commands:

```sh
cp build/*.so .
python python_test_mpl.py tests/grow.sexp 2> stderr_python.txt 
```

If you want to visualize preset of animation, first, install `ffmpeq`
```sh
# Mac
brew install ffmpeg
# Linux
apt install ffmpeg libffmpeg
```


## Julia Build
In your julia project:
```sh
using Pkg;
Pkg.develop(path=joinpath(first(DEPOT_PATH), "packages", "AutumnInterpreter"))
Pkg.add("Plots") # This is for visualization
Pkg.add("PlotlyJS") # This is for visualization
Pkg.add("JSON3") # This is for visualization
Pkg.add("WebIO")
Pkg.add("Observables")
Pkg.add("JSExpr")
using AutumnInterpreter
```

# WASM Build
```sh
sh install_scripts/setup_emscripten.sh
source ./emsdk/emsdk_env.sh
make web
cp interpreter_web.* ./flask_server/static/
```