| 
									
										
										
										
											2009-03-22 21:16:31 -04:00
										 |  |  | ! Copyright (C) 2006, 2009 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2008-08-30 01:05:27 -04:00
										 |  |  | USING: kernel sequences namespaces assocs graphs math math.order ;
 | 
					
						
							| 
									
										
										
										
											2009-03-22 21:16:31 -04:00
										 |  |  | IN: definitions | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-06 14:34:38 -04:00
										 |  |  | MIXIN: definition | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-03-20 16:00:49 -04:00
										 |  |  | ERROR: no-compilation-unit definition ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-22 21:16:31 -04:00
										 |  |  | SYMBOLS: inlined-dependency flushed-dependency called-dependency ;
 | 
					
						
							| 
									
										
										
										
											2008-08-30 01:05:27 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-03 04:51:28 -05:00
										 |  |  | : set-in-unit ( value key assoc -- )
 | 
					
						
							|  |  |  |     [ set-at ] [ no-compilation-unit ] if* ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-30 03:31:27 -04:00
										 |  |  | SYMBOL: changed-definitions | 
					
						
							| 
									
										
										
										
											2008-08-30 01:05:27 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-31 02:34:00 -04:00
										 |  |  | : changed-definition ( defspec -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-03 04:51:28 -05:00
										 |  |  |     inlined-dependency swap changed-definitions get set-in-unit ;
 | 
					
						
							| 
									
										
										
										
											2008-08-31 02:34:00 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-22 21:16:31 -04:00
										 |  |  | SYMBOL: changed-effects | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : changed-effect ( word -- )
 | 
					
						
							|  |  |  |     dup changed-effects get set-in-unit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-31 02:34:00 -04:00
										 |  |  | SYMBOL: changed-generics | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 20:39:32 -04:00
										 |  |  | SYMBOL: outdated-generics | 
					
						
							| 
									
										
										
										
											2008-11-03 04:51:28 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-08-30 03:32:17 -04:00
										 |  |  | SYMBOL: new-classes | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : new-class ( word -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-03 04:51:28 -05:00
										 |  |  |     dup new-classes get set-in-unit ;
 | 
					
						
							| 
									
										
										
										
											2008-08-30 03:32:17 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : new-class? ( word -- ? )
 | 
					
						
							|  |  |  |     new-classes get key? ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | GENERIC: where ( defspec -- loc )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object where drop f ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: set-where ( loc defspec -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  | GENERIC: forget* ( defspec -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-06 14:26:07 -04:00
										 |  |  | M: f forget* drop ;
 | 
					
						
							| 
									
										
										
										
											2008-01-09 16:51:55 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: forgotten-definitions | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : forgotten-definition ( defspec -- )
 | 
					
						
							| 
									
										
										
										
											2009-03-07 00:33:30 -05:00
										 |  |  |     dup forgotten-definitions get set-in-unit ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-07 00:33:30 -05:00
										 |  |  | : forget ( defspec -- ) [ forgotten-definition ] [ forget* ] bi ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-10-09 17:35:09 -04:00
										 |  |  | : forget-all ( definitions -- ) [ forget ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | GENERIC: definer ( defspec -- start end )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: definition ( defspec -- seq )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: crossref | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: uses ( defspec -- seq )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object uses drop f ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : xref ( defspec -- ) dup uses crossref get add-vertex ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-06-06 21:47:09 -04:00
										 |  |  | : usage ( defspec -- seq ) crossref get at keys ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: irrelevant? ( defspec -- ? )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object irrelevant? drop f ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: smart-usage ( defspec -- seq )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: f smart-usage drop \ f smart-usage ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: object smart-usage usage [ irrelevant? not ] filter ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | : unxref ( defspec -- )
 | 
					
						
							|  |  |  |     dup uses crossref get remove-vertex ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : delete-xref ( defspec -- )
 | 
					
						
							|  |  |  |     dup unxref crossref get delete-at ;
 |