| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | ! Copyright (C) 2008 Slava Pestov. | 
					
						
							|  |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							|  |  |  | USING: kernel continuations assocs namespaces sequences words | 
					
						
							| 
									
										
										
										
											2008-02-25 20:37:43 -05:00
										 |  |  | vocabs definitions hashtables init ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | IN: compiler.units | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: old-definitions | 
					
						
							|  |  |  | SYMBOL: new-definitions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: redefine-error def ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : redefine-error ( definition -- )
 | 
					
						
							|  |  |  |     \ redefine-error construct-boa | 
					
						
							|  |  |  |     { { "Continue" t } } throw-restarts drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : add-once ( key assoc -- )
 | 
					
						
							|  |  |  |     2dup key? [ over redefine-error ] when dupd set-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : (remember-definition) ( definition loc assoc -- )
 | 
					
						
							|  |  |  |     >r over set-where r> add-once ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : remember-definition ( definition loc -- )
 | 
					
						
							|  |  |  |     new-definitions get first (remember-definition) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : remember-class ( class loc -- )
 | 
					
						
							|  |  |  |     over new-definitions get first key? [ dup redefine-error ] when
 | 
					
						
							|  |  |  |     new-definitions get second (remember-definition) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : forward-reference? ( word -- ? )
 | 
					
						
							|  |  |  |     dup old-definitions get assoc-stack
 | 
					
						
							|  |  |  |     [ new-definitions get assoc-stack not ] | 
					
						
							|  |  |  |     [ drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: recompile-hook | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <definitions> ( -- pair ) { H{ } H{ } } [ clone ] map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: definition-observers | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: definitions-changed ( assoc obj -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-25 20:37:43 -05:00
										 |  |  | [ V{ } clone definition-observers set-global ] | 
					
						
							|  |  |  | "compiler.units" add-init-hook | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : add-definition-observer ( obj -- )
 | 
					
						
							| 
									
										
										
										
											2008-02-25 20:37:43 -05:00
										 |  |  |     definition-observers get push ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : remove-definition-observer ( obj -- )
 | 
					
						
							|  |  |  |     definition-observers get delete ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : notify-definition-observers ( assoc -- )
 | 
					
						
							|  |  |  |     definition-observers get
 | 
					
						
							| 
									
										
										
										
											2008-01-09 17:36:30 -05:00
										 |  |  |     [ definitions-changed ] with each ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  | : changed-vocabs ( assoc -- vocabs )
 | 
					
						
							|  |  |  |     [ drop word? ] assoc-subset | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  |     [ drop word-vocabulary dup [ vocab ] when dup ] assoc-map ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : changed-definitions ( -- assoc )
 | 
					
						
							|  |  |  |     H{ } clone
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  |     dup forgotten-definitions get update | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  |     dup new-definitions get first update | 
					
						
							|  |  |  |     dup new-definitions get second update | 
					
						
							|  |  |  |     dup changed-words get update | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  |     dup dup changed-vocabs update ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-24 03:19:38 -05:00
										 |  |  | : compile ( words -- )
 | 
					
						
							|  |  |  |     recompile-hook get call
 | 
					
						
							|  |  |  |     dup [ drop crossref? ] assoc-contains? | 
					
						
							|  |  |  |     modify-code-heap ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: post-compile-tasks | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : after-compilation ( quot -- )
 | 
					
						
							|  |  |  |     post-compile-tasks get push ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-25 04:38:37 -05:00
										 |  |  | : call-recompile-hook ( -- )
 | 
					
						
							|  |  |  |     changed-words get keys
 | 
					
						
							|  |  |  |     compiled-usages recompile-hook get call ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : call-post-compile-tasks ( -- )
 | 
					
						
							|  |  |  |     post-compile-tasks get [ call ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : finish-compilation-unit ( -- )
 | 
					
						
							| 
									
										
										
										
											2008-02-25 04:38:37 -05:00
										 |  |  |     call-recompile-hook | 
					
						
							|  |  |  |     call-post-compile-tasks | 
					
						
							|  |  |  |     dup [ drop crossref? ] assoc-contains? modify-code-heap | 
					
						
							| 
									
										
										
										
											2008-01-09 13:41:58 -05:00
										 |  |  |     changed-definitions notify-definition-observers ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : with-compilation-unit ( quot -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         H{ } clone changed-words set
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  |         H{ } clone forgotten-definitions set
 | 
					
						
							| 
									
										
										
										
											2008-02-24 03:19:38 -05:00
										 |  |  |         V{ } clone post-compile-tasks set
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  |         <definitions> new-definitions set
 | 
					
						
							|  |  |  |         <definitions> old-definitions set
 | 
					
						
							|  |  |  |         [ finish-compilation-unit ] | 
					
						
							|  |  |  |         [ ] cleanup
 | 
					
						
							|  |  |  |     ] with-scope ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-24 03:19:38 -05:00
										 |  |  | : compile-call ( quot -- )
 | 
					
						
							|  |  |  |     [ define-temp ] with-compilation-unit execute ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : default-recompile-hook ( words -- alist )
 | 
					
						
							|  |  |  |     [ f ] { } map>assoc ;
 | 
					
						
							| 
									
										
										
										
											2008-02-17 19:38:29 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | recompile-hook global
 | 
					
						
							| 
									
										
										
										
											2008-02-17 19:38:29 -05:00
										 |  |  | [ [ default-recompile-hook ] or ] | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | change-at
 |