Welcome to the Esprit project - ClojureScript for Microcontrollers (well, just the ESP32 for now).
Esprit attempts to provide a functional ClojureScript environment running atop the Espruino JavaScript interpreter. As Espruino isn't quite feature-complete, some modifications to ClojureScript are necessary. This project attempts to automate that process and provide some functionality for Clojure-friendly abstractions to hardware-level configurations.
If you haven't already, check out the Clojure/north talk and the Apropos episode. For help, check out the #esprit channel on the Clojurians Slack.
To run Esprit, you will need an ESP32. However, not every ESP32 is created equal. Specifically, we require modules with at least 8MB of flash. The ESP32 WROVER module with 8MB of PSIRAM has been shown to work great. Additionally, you can use the purpose-built Esprit board, which comes pre-configured with battery management and blikenlights galore.
All of the interaction with the board itself is done with Espressif's esptool.py. Make sure this is installed, and on your path before proceeding. (If using Homebrew, you can do brew install esptool.)
We are assuming that the device is plugged in to your machine via USB.
Note: If you are using the Esprit board, you will need the Silicon Labs CP2102N USB to UART chip drivers if they are not already installed on your computer. Also note that, even though the Esprit board might be visible to your computer via USB, it is recommended that the latest Silicon Labs drivers be installed to ensure reliable operation.
Alright hot shot, wanna jump in head first?
Create a deps.edn file with ClojureScript and Esprit
{:deps {org.clojure/clojurescript {:mvn/version "1.10.764"}
        esprit/esprit {:mvn/version "1.0.0"}}}
Build a js file, containing the Esprit REPL, baking WiFi credentials into it (change MySSID and MyWiFiPassword):
clj -M -m cljs.main -co '{:closure-defines {esprit.repl/wifi-ssid "MySSID" esprit.repl/wifi-password "MyWiFiPassword"} :optimizations :simple :target :none :browser-repl false :process-shim false}' -c esprit.repl
Normally we'd just have the Espruino persist the WiFi info via its existing capability to do so, but this is currently not reliable with this particular modified build, while baking it in as illustrated above works every time.
Then make a ROM binary from the compiled ClojureScript using
clj -M -m esprit.make-rom
Now that your binary is ready, we now have to prepare the board for upload.
Note: These steps require
esptool.pyon yourPATH. By default, this tool will search for the USB port where the ESP32 is connected, and this can be a bit slow. The search can be skipped by creating aconfig.ednfile specifying the port. For example, if you are using the Esprit board, its contents would be:{:serial-port "/dev/cu.SLAB_USBtoUART"}.
First, erase whatever is on your board
clj -M -m esprit.flash --erase
Now bootstrap the Espruino runtime
clj -M -m esprit.flash --bootstrap
Finally, flash your binary
clj -M -m esprit.flash --flash out/main.bin
Open up the ESP32's com port, say with screen at the default baudrate of 115200.
screen <your serial port> 115200
In the above, insert the serial port for your board. For example, with the Esprit board, you would connect via screen /dev/cu.SLAB_USBtoUART 115200.
After connecting via screen, it may be a good idea to reset your board in case you may have missed any messages printed during boot. (On the Esprit board, this can be done by pressing the reset button.)
It can take about 15 seconds to load the ClojureScript runtime. (The Esprit board will flash its EVAL LED while this is occcuring.)
Then the code will attempt to join the WiFi. (The Esprit board will dimly light the CONN LED while this is occuring, and once connected to WiFi it will switch to doing short pulses until a REPL connection is established.)
Once the device is connected to WiFi, it will print a message like the following to the serial port like:
Ready for REPL Connections
Establish an Esprit REPL by executing
clj -M -m cljs.main -re esprit -ro '{:endpoint-address "10.0.0.1"}' -r
Copy this command, and then exit your terminal session (in screen this is done via Ctrl-a, k, y), and then issue the copied command to start the REPL.
At this point, the REPL connection traffic is managed via TCP over WiFi. If your board is powered by some alternate means (LiPo battery, for example), you can disconnect the USB cable and the REPL will remain live.
Can you improve this documentation? These fine people already did:
Mike Fikes, Aleš Roubíček & Kiran ShilaEdit on GitHub
cljdoc builds & hosts documentation for Clojure/Script libraries
| Ctrl+k | Jump to recent docs | 
| ← | Move to previous article | 
| → | Move to next article | 
| Ctrl+/ | Jump to the search field |