factor/core/compiler/compiler.factor

70 lines
1.8 KiB
Factor
Raw Normal View History

2007-09-20 18:09:08 -04:00
! Copyright (C) 2004, 2007 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
USING: kernel namespaces arrays sequences io inference.backend
2007-12-24 19:40:09 -05:00
generator debugger math.parser prettyprint words words.private
continuations vocabs assocs alien.compiler dlists optimizer
definitions ;
2007-09-20 18:09:08 -04:00
IN: compiler
SYMBOL: compiler-hook
: compile-begins ( word -- )
compiler-hook get [ call ] when*
"quiet" get [ drop ] [ "Compiling " write . flush ] if ;
: compiled-usage ( word -- seq )
#! XXX
usage [ word? ] subset ;
: ripple-up ( word effect -- )
over "compiled-effect" word-prop =
[ drop ] [
compiled-usage
[ "was-compiled" word-prop ] subset
[ queue-compile ] each
] if ;
: save-effect ( word effect -- )
over t "was-compiled" set-word-prop
"compiled-effect" set-word-prop ;
: (compile) ( word -- )
[
dup compile-begins
dup word-dataflow optimize >r over dup r> generate
] [
2007-12-24 21:54:45 -05:00
print-error f over compiled get set-at f
] recover
2007-12-26 21:37:18 -05:00
2drop ;
! 2dup ripple-up save-effect ;
: delete-any ( assoc -- element )
[ [ 2drop t ] assoc-find 2drop dup ] keep delete-at ;
: compile-loop ( assoc -- )
dup assoc-empty?
[ drop ] [ dup delete-any (compile) compile-loop ] if ;
2007-12-26 20:21:46 -05:00
: recompile ( words -- )
[
H{ } clone compile-queue set
H{ } clone compiled set
[ queue-compile ] each
compile-queue get compile-loop
compiled get >alist modify-code-heap
] with-scope ; inline
2007-12-26 20:21:46 -05:00
: compile ( words -- )
[ compiled? not ] subset recompile ;
: compile-quot ( quot -- word )
H{ } clone changed-words [
2007-12-26 20:21:46 -05:00
define-temp dup 1array recompile
] with-variable ;
2007-09-20 18:09:08 -04:00
: compile-call ( quot -- )
compile-quot execute ;
2007-09-20 18:09:08 -04:00
: compile-all ( -- )
2007-12-26 20:21:46 -05:00
all-words recompile ;