1
Fork 0
mirror of https://git.savannah.gnu.org/git/guile.git synced 2025-05-20 11:40:18 +02:00

compile ecmascript's parser. yay! instant load-time!

* module/language/ghil/compile-glil.scm (codegen): If there are more than
  255 arguments, make a list and use apply instead of calling directly.

* module/language/Makefile.am: Now we can compile parse.scm. Yay!

* module/language/scheme/compile-ghil.scm: Add a note.

* module/language/ecmascript/compile-ghil.scm: Add a note.
This commit is contained in:
Andy Wingo 2009-02-21 20:07:57 +01:00
parent 594d9d4c48
commit aec8febc46
4 changed files with 13 additions and 5 deletions

View file

@ -2,15 +2,12 @@ SUBDIRS=scheme ghil glil assembly bytecode objcode value
SOURCES=ghil.scm glil.scm assembly.scm \
ecmascript/parse-lalr.scm \
ecmascript/tokenize.scm \
ecmascript/parse.scm \
ecmascript/spec.scm \
ecmascript/impl.scm \
ecmascript/base.scm \
ecmascript/function.scm \
ecmascript/array.scm \
ecmascript/compile-ghil.scm
# unfortunately, the one that we want to compile can't yet be compiled
# -- too many external vars, or something. seems like we need to do
# closure elimination or something.
NOCOMP_SOURCES = ecmascript/parse.scm
modpath = language
include $(top_srcdir)/am/guilec

View file

@ -46,6 +46,8 @@
(@implv ,e ,l ,sym)
,args))
;; The purpose, you ask? To avoid non-tail recursion when expanding a
;; long pmatch sequence.
(define-macro (ormatch x . clauses)
(let ((X (gensym)))
`(let ((,X ,x))

View file

@ -382,7 +382,14 @@
;; ARGS...
;; ([tail-]call NARGS)
(comp-push proc)
(push-call! loc (if tail 'goto/args 'call) args)
(let ((nargs (length args)))
(cond ((< nargs 255)
(push-call! loc (if tail 'goto/args 'call) args))
(else
(push-call! loc 'mark '())
(for-each comp-push args)
(push-call! loc 'list-mark '())
(push-code! loc (make-glil-call (if tail 'goto/apply 'apply) 2)))))
(maybe-drop))
((<ghil-mv-call> env loc producer consumer)

View file

@ -381,6 +381,8 @@
;; FIXME: not hygienic, relies on @apply not being shadowed
(,args (retrans `(@apply ,@args))))
;; FIXME: we could add inliners for `list' and `vector'
(define-scheme-translator @apply
((,proc ,arg1 . ,args)
(let ((args (cons (retrans arg1) (map retrans args))))