# an integrated Ludus interpreter # devised in order to run under wasm # takes a string, returns a string with a json object # (try (os/cd "janet") ([_] nil)) # for REPL (import /src/scanner :as s) (import /src/parser :as p) (import /src/validate :as v) (import /src/interpreter :as i) (import /src/errors :as e) (import /src/base :as b) (import /src/prelude :as prelude) (import /src/json :as j) (defn ludus [source] (when (= :error prelude/pkg) (error "could not load prelude")) (def ctx @{:^parent prelude/ctx}) (def errors @[]) (var result @"") (def console @"") (setdyn :out console) (def out @{:errors errors :result result :io @{ :stdout @{:proto [:text-stream "0.1.0"] :data console} :turtle @{:proto [:turtle-graphics "0.1.0"] :data @[]}}}) (def scanned (s/scan source)) (when (any? (scanned :errors)) (each err (scanned :errors) (e/scan-error err)) (break (-> out j/encode string))) (def parsed (p/parse scanned)) (when (any? (parsed :errors)) (each err (parsed :errors) (e/parse-error err)) (break (-> out j/encode string))) (def validated (v/valid parsed ctx)) (when (any? (validated :errors)) (each err (validated :errors) (e/validation-error err)) (break (-> out j/encode string))) (try (set result (i/interpret (parsed :ast) ctx)) ([err] (e/runtime-error err) (break (-> out j/encode string)))) (setdyn :out stdout) (set (out :result) (b/show result)) (set (((out :io) :turtle) :data) (get-in prelude/pkg [:turtle_commands :^value])) (try (i/interpret prelude/post/ast ctx) ([err] (e/runtime-error err))) (-> out j/encode string)) (comment # (do # (def start (os/clock)) (def source ` fd! (100) rt! (0.25) fd! (100) lt! (0.25) fd! (100) setheading! (0.75) unbox (turtle_state) `) (def out (-> source ludus j/decode )) # (def end (os/clock)) (setdyn :out stdout) (pp out) (def console (out "console")) (print console) (def result (out "result")) (print result) # (print (- end start)) )