| 
									
										
										
										
											2009-08-20 16:10:42 -04:00
										 |  |  | ! (c)2009 Joe Groff bsd license | 
					
						
							| 
									
										
										
										
											2009-08-29 18:41:21 -04:00
										 |  |  | USING: accessors arrays assocs combinators.short-circuit | 
					
						
							|  |  |  | compiler.units debugger init io | 
					
						
							| 
									
										
										
										
											2009-08-28 06:32:34 -04:00
										 |  |  | io.streams.null kernel namespaces prettyprint sequences | 
					
						
							| 
									
										
										
										
											2009-08-20 17:17:36 -04:00
										 |  |  | source-files.errors summary tools.crossref | 
					
						
							|  |  |  | tools.crossref.private tools.errors words ;
 | 
					
						
							|  |  |  | IN: tools.deprecation | 
					
						
							| 
									
										
										
										
											2009-08-20 16:10:42 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | SYMBOL: +deprecation-note+ | 
					
						
							|  |  |  | SYMBOL: deprecation-notes | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | deprecation-notes [ H{ } clone ] initialize
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: deprecation-note < source-file-error ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: deprecation-note error-type drop +deprecation-note+ ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | TUPLE: deprecated-usages asset usages ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : :deprecations ( -- )
 | 
					
						
							|  |  |  |     deprecation-notes get-global values errors. ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | T{ error-type | 
					
						
							|  |  |  |     { type +deprecation-note+ } | 
					
						
							|  |  |  |     { word ":deprecations" } | 
					
						
							|  |  |  |     { plural "deprecated word usages" } | 
					
						
							|  |  |  |     { icon "vocab:ui/tools/error-list/icons/deprecation-note.tiff" } | 
					
						
							|  |  |  |     { quot [ deprecation-notes get values ] } | 
					
						
							|  |  |  |     { forget-quot [ deprecation-notes get delete-at ] } | 
					
						
							|  |  |  | } define-error-type | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : <deprecation-note> ( error word -- deprecation-note )
 | 
					
						
							|  |  |  |     \ deprecation-note <definition-error> ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : deprecation-note ( word usages -- )
 | 
					
						
							|  |  |  |     [ deprecated-usages boa ] | 
					
						
							|  |  |  |     [ drop <deprecation-note> ] | 
					
						
							|  |  |  |     [ drop deprecation-notes get-global set-at ] 2tri ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : clear-deprecation-note ( word -- )
 | 
					
						
							|  |  |  |     deprecation-notes get-global delete-at ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-28 06:31:27 -04:00
										 |  |  | : check-deprecations ( usage -- )
 | 
					
						
							|  |  |  |     dup word? [ | 
					
						
							| 
									
										
										
										
											2009-08-29 18:41:21 -04:00
										 |  |  |         dup { [ "forgotten" word-prop ] [ deprecated? ] } 1|| | 
					
						
							| 
									
										
										
										
											2009-08-28 06:31:27 -04:00
										 |  |  |         [ clear-deprecation-note ] [ | 
					
						
							|  |  |  |             dup def>> uses [ deprecated? ] filter
 | 
					
						
							|  |  |  |             [ clear-deprecation-note ] [ >array deprecation-note ] if-empty
 | 
					
						
							|  |  |  |         ] if
 | 
					
						
							|  |  |  |     ] [ drop ] if ;
 | 
					
						
							| 
									
										
										
										
											2009-08-20 16:10:42 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: deprecated-usages summary | 
					
						
							|  |  |  |     drop "Deprecated words used" ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: deprecated-usages error. | 
					
						
							|  |  |  |     "The definition of " write
 | 
					
						
							|  |  |  |     dup asset>> pprint | 
					
						
							|  |  |  |     " uses these deprecated words:" write nl
 | 
					
						
							|  |  |  |     usages>> [ "    " write pprint nl ] each ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | SINGLETON: deprecation-observer | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : initialize-deprecation-notes ( -- )
 | 
					
						
							| 
									
										
										
										
											2009-08-28 06:32:34 -04:00
										 |  |  |     [ | 
					
						
							|  |  |  |         get-crossref [ drop deprecated? ] assoc-filter
 | 
					
						
							|  |  |  |         values [ keys [ check-deprecations ] each ] each
 | 
					
						
							|  |  |  |     ] with-null-writer ;
 | 
					
						
							| 
									
										
										
										
											2009-08-20 16:10:42 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: deprecation-observer definitions-changed | 
					
						
							|  |  |  |     drop keys [ word? ] filter
 | 
					
						
							|  |  |  |     dup [ deprecated? ] filter empty?
 | 
					
						
							|  |  |  |     [ [ check-deprecations ] each ] | 
					
						
							|  |  |  |     [ drop initialize-deprecation-notes ] if ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-20 17:18:06 -04:00
										 |  |  | [ \ deprecation-observer add-definition-observer ]  | 
					
						
							| 
									
										
										
										
											2009-10-19 22:17:02 -04:00
										 |  |  | "tools.deprecation" add-startup-hook | 
					
						
							| 
									
										
										
										
											2009-08-20 16:10:42 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | initialize-deprecation-notes |