+ -)
(values-list /))
-(export '(&body &key &optional &rest * ** *** *gensym-counter* *package* + ++
- +++ - / // /// 1+ 1- < <= = = > >= and append apply aref arrayp
- assoc atom block boundp butlast cadar caaar caadr cdaar cdadr
- cddar caaaar caaadr caadar caaddr cadaar cadadr caddar cdaaar
- cdaadr cdadar cdaddr cddaar cddadr cdddar cddddr caar cadddr caddr
- cadr car car case catch cdar cdddr cddr cdr cdr char
- char-code char= code-char cond cons consp constantly
- copy-list copy-tree decf declaim declare defconstant define-setf-expander
- define-symbol-macro defmacro defparameter defun defvar
- digit-char digit-char-p disassemble do do* documentation
- dolist dotimes ecase eq eql equal error eval every export expt
- fdefinition find-package find-symbol first flet format fourth fset
- funcall function functionp gensym get-internal-real-time
- get-setf-expansion get-universal-time go identity if in-package
- incf integerp intern keywordp labels lambda last length let let* list
- list* list-all-packages listp loop make-array make-package
- make-symbol mapcar member minusp mod multiple-value-bind
- multiple-value-call multiple-value-list multiple-value-prog1
- nconc nil not nreconc nth nthcdr null numberp or otherwise
- package-name package-use-list packagep parse-integer plusp pop
- prin1-to-string print proclaim prog1 prog2 progn psetq push
- quote read-from-string remove remove-if remove-if-not return
- return-from revappend reverse rplaca rplacd second set setf
- setq some string string-upcase string= stringp subseq subst
- symbol-function symbol-name symbol-package symbol-plist
- symbol-value symbolp t tagbody third throw truncate unless
- unwind-protect values values-list variable warn when write-line
- write-string zerop))
+(export '(&body &key &optional &rest * ** *** *features* *gensym-counter*
+ *package* *print-circle* + ++ +++ - / // /// 1+ 1- < <= = = > >= acons
+ adjoin alpha-char-p and append apply aref arrayp assoc atom block
+ boundp butlast caaaar caaadr caaar caadar caaddr caadr caar cadaar
+ cadadr cadar caddar cadddr caddr cadr car car case catch cdaaar
+ cdaadr cdaar cdadar cdaddr cdadr cdar cddaar cddadr cddar cdddar
+ cddddr cdddr cddr cdr cdr char char-code char= code-char cond cons
+ consp constantly copy-alist copy-list copy-tree decf declaim declare
+ defconstant define-setf-expander define-symbol-macro defmacro
+ defparameter defun defvar destructuring-bind digit-char digit-char-p
+ disassemble do do* documentation dolist dotimes ecase eighth eq eql
+ equal error eval every export expt fdefinition fifth find
+ find-package find-symbol first flet format fourth fboundp fset funcall
+ function functionp gensym get-internal-real-time get-setf-expansion
+ get-universal-time go identity if in-package incf integerp intern
+ intersection keywordp labels lambda last length let let*
+ lisp-implementation-type list list* list-all-packages listp loop
+ make-array make-package make-symbol mapc mapcar member minusp mod
+ multiple-value-bind multiple-value-call multiple-value-list
+ multiple-value-prog1 nconc nil ninth not nreconc nth nthcdr null
+ numberp or otherwise package-name package-use-list packagep pairlis
+ parse-integer plusp pop prin1-to-string print proclaim prog prog1
+ prog2 progn psetq push quote rassoc read-from-string remove remove-if
+ remove-if-not return return-from revappend reverse rplaca rplacd
+ second set setf setq seventh sixth some string string-upcase string=
+ stringp sublis subseq subst symbol-function symbol-name symbol-package
+ symbol-plist symbol-value symbolp t tagbody tailp tenth third throw
+ tree-equal truncate unless unwind-protect values values-list variable
+ vector-push-extend warn when write-line write-string zerop))
(setq *package* *user-package*)
+;;; Set some external entry point to the Lisp implementation to the
+;;; console. It would not be necessary when FFI is finished.
(js-eval "var lisp")
(%js-vset "lisp" (new))
(%js-vset "lisp.read" #'ls-read-from-string)
(%js-vset "lisp.evalString" (lambda (str) (eval (ls-read-from-string str))))
(%js-vset "lisp.evalInput" (lambda (str) (eval-interactive (ls-read-from-string str))))
(%js-vset "lisp.compileString" (lambda (str) (ls-compile-toplevel (ls-read-from-string str) t)))
-
-;; Set the initial global environment to be equal to the host global
-;; environment at this point of the compilation.
-(eval-when-compile
- (toplevel-compilation
- (ls-compile `(setq *environment* ',*environment*))))
-
-(eval-when-compile
- (toplevel-compilation
- (ls-compile
- `(progn
- ,@(mapcar (lambda (s) `(%intern-symbol (%js-vref ,(cdr s))))
- *literal-table*)
- (setq *literal-table* ',*literal-table*)
- (setq *variable-counter* ,*variable-counter*)
- (setq *gensym-counter* ,*gensym-counter*)))))
-
-(eval-when-compile
- (toplevel-compilation
- (ls-compile
- `(setq *literal-counter* ,*literal-counter*))))