# 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 @[]) (def draw @[]) (var result @"") (def console @"") (def out @{:errors errors :draw draw :result result :console console}) (def scanned (s/scan source)) (when (any? (scanned :errors)) (set (out :errors) (scanned :errors)) (each err (scanned :errors) (e/scan-error err)) (break out)) (def parsed (p/parse scanned)) (when (any? (parsed :errors)) (set (out :errors) (parsed :errors)) (each err (parsed :errors) (e/parse-error err)) (break out)) (def validated (v/valid parsed ctx)) (when (any? (validated :errors)) (set (out :errors) (validated :errors)) (each err (validated :errors) (e/validation-error err)) (break out)) (setdyn :out console) (try (set result (i/interpret (parsed :ast) ctx)) ([err] (e/runtime-error err) (set (out :errors) [err]) (break out))) (setdyn :out stdout) (set (out :result) (b/show result)) (var post @{}) (try (set post (i/interpret prelude/post/ast ctx)) ([err] (e/runtime-error err))) (set (out :draw) (post :draw)) (string (j/encode out)))