| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | ! Copyright (C) 2008, 2010 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-08-31 02:34:00 -04:00
										 |  |  | USING: accessors arrays kernel continuations assocs namespaces | 
					
						
							| 
									
										
										
										
											2010-01-31 08:48:39 -05:00
										 |  |  | sequences words vocabs definitions hashtables init sets math | 
					
						
							|  |  |  | math.order classes classes.private classes.algebra classes.tuple | 
					
						
							|  |  |  | classes.tuple.private generic source-files.errors kernel.private ;
 | 
					
						
							| 
									
										
										
										
											2010-02-26 16:01:01 -05:00
										 |  |  | FROM: namespaces => set ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | IN: compiler.units | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: old-definitions | 
					
						
							|  |  |  | SYMBOL: new-definitions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: redefine-error def ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : redefine-error ( definition -- )
 | 
					
						
							| 
									
										
										
										
											2010-02-19 19:41:33 -05:00
										 |  |  |     \ redefine-error boa throw-continue ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : add-once ( key assoc -- )
 | 
					
						
							| 
									
										
										
										
											2008-05-25 20:44:37 -04:00
										 |  |  |     2dup key? [ over redefine-error ] when conjoin ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : (remember-definition) ( definition loc assoc -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-02 04:10:27 -05:00
										 |  |  |     [ over set-where ] dip add-once ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : remember-definition ( definition loc -- )
 | 
					
						
							|  |  |  |     new-definitions get first (remember-definition) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-07 01:42:43 -05:00
										 |  |  | : fake-definition ( definition -- )
 | 
					
						
							|  |  |  |     old-definitions get [ delete-at ] with each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : remember-class ( class loc -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-02 04:10:27 -05:00
										 |  |  |     [ dup new-definitions get first key? [ dup redefine-error ] when ] dip
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  |     new-definitions get second (remember-definition) ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : forward-reference? ( word -- ? )
 | 
					
						
							|  |  |  |     dup old-definitions get assoc-stack
 | 
					
						
							|  |  |  |     [ new-definitions get assoc-stack not ] | 
					
						
							|  |  |  |     [ drop f ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 20:39:32 -04:00
										 |  |  | SYMBOL: compiler-impl | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | HOOK: update-call-sites compiler-impl ( class generic -- words )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-20 16:25:53 -05:00
										 |  |  | : changed-call-sites ( class generic -- )
 | 
					
						
							|  |  |  |     update-call-sites [ changed-definition ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | M: generic update-generic ( class generic -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-20 16:25:53 -05:00
										 |  |  |     [ changed-call-sites ] | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  |     [ remake-generic drop ] | 
					
						
							| 
									
										
										
										
											2010-01-29 11:10:10 -05:00
										 |  |  |     [ changed-conditionally drop ] | 
					
						
							|  |  |  |     2tri ;
 | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: sequence update-methods ( class seq -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-29 03:53:14 -05:00
										 |  |  |     implementors [ update-generic ] with each ;
 | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 20:39:32 -04:00
										 |  |  | HOOK: recompile compiler-impl ( words -- alist )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-08 07:08:04 -05:00
										 |  |  | HOOK: to-recompile compiler-impl ( -- words )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | HOOK: process-forgotten-words compiler-impl ( words -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 08:49:05 -05:00
										 |  |  | : compile ( words -- )
 | 
					
						
							|  |  |  |     recompile t f modify-code-heap ;
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-15 20:15:28 -04:00
										 |  |  | ! Non-optimizing compiler | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  | M: f update-call-sites | 
					
						
							|  |  |  |     2drop { } ;
 | 
					
						
							| 
									
										
										
										
											2009-11-08 07:08:04 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: f to-recompile | 
					
						
							| 
									
										
										
										
											2010-01-20 10:23:20 -05:00
										 |  |  |     changed-definitions get [ drop word? ] assoc-filter keys ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: f recompile | 
					
						
							|  |  |  |     [ dup def>> ] { } map>assoc ;
 | 
					
						
							| 
									
										
										
										
											2009-11-08 07:08:04 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: f process-forgotten-words drop ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-01 06:52:05 -04:00
										 |  |  | : without-optimizer ( quot -- )
 | 
					
						
							|  |  |  |     [ f compiler-impl ] dip with-variable ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : <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 ] | 
					
						
							| 
									
										
										
										
											2009-10-19 22:17:02 -04:00
										 |  |  | "compiler.units" add-startup-hook | 
					
						
							| 
									
										
										
										
											2008-02-25 20:37:43 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-01 09:21:31 -04:00
										 |  |  | ! This goes here because vocabs cannot depend on init | 
					
						
							|  |  |  | [ V{ } clone vocab-observers set-global ] | 
					
						
							| 
									
										
										
										
											2009-10-19 22:17:02 -04:00
										 |  |  | "vocabs" add-startup-hook | 
					
						
							| 
									
										
										
										
											2009-05-01 09:21:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 -- )
 | 
					
						
							| 
									
										
										
										
											2009-10-28 01:23:08 -04:00
										 |  |  |     definition-observers get remove-eq! drop ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : 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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | ! Incremented each time stack effects potentially changed, used | 
					
						
							|  |  |  | ! by compiler.tree.propagation.call-effect for call( and execute( | 
					
						
							|  |  |  | ! inline caching | 
					
						
							| 
									
										
										
										
											2010-01-13 00:08:18 -05:00
										 |  |  | : effect-counter ( -- n ) 47 special-object ; inline
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-29 03:53:14 -05:00
										 |  |  | GENERIC: always-bump-effect-counter? ( defspec -- ? )
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-01-29 03:53:14 -05:00
										 |  |  | M: object always-bump-effect-counter? drop f ;
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  | : changed-vocabs ( assoc -- vocabs )
 | 
					
						
							| 
									
										
										
										
											2008-04-26 00:12:44 -04:00
										 |  |  |     [ drop word? ] assoc-filter
 | 
					
						
							| 
									
										
										
										
											2008-06-28 03:36:20 -04:00
										 |  |  |     [ drop vocabulary>> dup [ vocab ] when dup ] assoc-map ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-04-05 08:00:09 -04:00
										 |  |  | : updated-definitions ( -- assoc )
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  |     H{ } clone
 | 
					
						
							| 
									
										
										
										
											2010-02-03 08:55:00 -05:00
										 |  |  |     forgotten-definitions get assoc-union!
 | 
					
						
							|  |  |  |     new-definitions get first assoc-union!
 | 
					
						
							|  |  |  |     new-definitions get second assoc-union!
 | 
					
						
							|  |  |  |     changed-definitions get assoc-union!
 | 
					
						
							|  |  |  |     maybe-changed get assoc-union!
 | 
					
						
							|  |  |  |     dup changed-vocabs assoc-union! ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-15 01:27:02 -04:00
										 |  |  | : process-forgotten-definitions ( -- )
 | 
					
						
							|  |  |  |     forgotten-definitions get keys
 | 
					
						
							| 
									
										
										
										
											2009-11-08 07:08:04 -05:00
										 |  |  |     [ [ word? ] filter process-forgotten-words ] | 
					
						
							| 
									
										
										
										
											2009-04-15 01:27:02 -04:00
										 |  |  |     [ [ delete-definition-errors ] each ] | 
					
						
							|  |  |  |     bi ;
 | 
					
						
							| 
									
										
										
										
											2008-06-11 03:58:38 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | : bump-effect-counter? ( -- ? )
 | 
					
						
							| 
									
										
										
										
											2010-01-29 03:53:14 -05:00
										 |  |  |     changed-effects get
 | 
					
						
							| 
									
										
										
										
											2010-01-29 08:58:39 -05:00
										 |  |  |     maybe-changed get
 | 
					
						
							| 
									
										
										
										
											2010-01-29 03:53:14 -05:00
										 |  |  |     changed-definitions get [ drop always-bump-effect-counter? ] assoc-filter
 | 
					
						
							|  |  |  |     3array assoc-combine new-words get assoc-diff assoc-empty? not ;
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : bump-effect-counter ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-13 00:08:18 -05:00
										 |  |  |     bump-effect-counter? [ | 
					
						
							|  |  |  |         47 special-object 0 or
 | 
					
						
							|  |  |  |         1 +
 | 
					
						
							|  |  |  |         47 set-special-object | 
					
						
							|  |  |  |     ] when ;
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : notify-observers ( -- )
 | 
					
						
							|  |  |  |     updated-definitions dup assoc-empty?
 | 
					
						
							|  |  |  |     [ drop ] [ notify-definition-observers notify-error-observers ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-01 08:49:05 -05:00
										 |  |  | : update-existing? ( defs -- ? )
 | 
					
						
							|  |  |  |     new-words get keys diff empty? not ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : reset-pics? ( -- ? )
 | 
					
						
							|  |  |  |     outdated-generics get assoc-empty? not ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | : finish-compilation-unit ( -- )
 | 
					
						
							| 
									
										
										
										
											2010-01-27 09:02:54 -05:00
										 |  |  |     [ ] [ | 
					
						
							|  |  |  |         remake-generics | 
					
						
							| 
									
										
										
										
											2010-02-01 08:49:05 -05:00
										 |  |  |         to-recompile [ | 
					
						
							|  |  |  |             recompile | 
					
						
							|  |  |  |             update-tuples | 
					
						
							|  |  |  |             process-forgotten-definitions | 
					
						
							|  |  |  |         ] keep update-existing? reset-pics? modify-code-heap | 
					
						
							| 
									
										
										
										
											2010-01-27 09:02:54 -05:00
										 |  |  |         bump-effect-counter | 
					
						
							|  |  |  |         notify-observers | 
					
						
							|  |  |  |     ] if-bootstrapping ;
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-02-03 09:20:48 -05:00
										 |  |  | TUPLE: nesting-observer new-words ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: nesting-observer definitions-changed new-words>> swap assoc-diff! drop ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : add-nesting-observer ( -- )
 | 
					
						
							|  |  |  |     new-words get nesting-observer boa
 | 
					
						
							|  |  |  |     [ nesting-observer set ] [ add-definition-observer ] bi ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : remove-nesting-observer ( -- )
 | 
					
						
							|  |  |  |     nesting-observer get remove-definition-observer ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-13 04:52:14 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							| 
									
										
										
										
											2008-05-28 20:34:18 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : with-nested-compilation-unit ( quot -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         H{ } clone changed-definitions set
 | 
					
						
							| 
									
										
										
										
											2010-01-29 08:58:39 -05:00
										 |  |  |         H{ } clone maybe-changed set
 | 
					
						
							| 
									
										
										
										
											2009-03-22 21:16:31 -04:00
										 |  |  |         H{ } clone changed-effects set
 | 
					
						
							| 
									
										
										
										
											2009-03-13 20:39:32 -04:00
										 |  |  |         H{ } clone outdated-generics set
 | 
					
						
							| 
									
										
										
										
											2008-05-28 20:34:18 -04:00
										 |  |  |         H{ } clone outdated-tuples set
 | 
					
						
							| 
									
										
										
										
											2009-11-13 08:17:00 -05:00
										 |  |  |         H{ } clone new-words set
 | 
					
						
							| 
									
										
										
										
											2010-02-03 09:20:48 -05:00
										 |  |  |         add-nesting-observer | 
					
						
							|  |  |  |         [ | 
					
						
							|  |  |  |             remove-nesting-observer | 
					
						
							|  |  |  |             finish-compilation-unit | 
					
						
							|  |  |  |         ] [ ] cleanup
 | 
					
						
							| 
									
										
										
										
											2008-05-28 20:34:18 -04:00
										 |  |  |     ] with-scope ; inline
 | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : with-compilation-unit ( quot -- )
 | 
					
						
							|  |  |  |     [ | 
					
						
							|  |  |  |         <definitions> new-definitions set
 | 
					
						
							|  |  |  |         <definitions> old-definitions set
 | 
					
						
							| 
									
										
										
										
											2010-02-03 09:20:48 -05:00
										 |  |  |         H{ } clone forgotten-definitions set
 | 
					
						
							|  |  |  |         with-nested-compilation-unit | 
					
						
							| 
									
										
										
										
											2008-01-09 04:52:08 -05:00
										 |  |  |     ] with-scope ; inline
 |