| 
									
										
										
										
											2010-02-15 19:56:11 -05:00
										 |  |  | ! Copyright (C) 2005, 2010 Slava Pestov. | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | ! See http://factorcode.org/license.txt for BSD license. | 
					
						
							| 
									
										
										
										
											2012-09-20 11:29:37 -04:00
										 |  |  | USING: accessors arrays assocs compiler.units effects fry | 
					
						
							|  |  |  | generalizations generic inspector io kernel locals macros math | 
					
						
							|  |  |  | namespaces prettyprint quotations sequences sequences.deep | 
					
						
							|  |  |  | sequences.generalizations sorting summary tools.time words ;
 | 
					
						
							|  |  |  | FROM: sequences => change-nth ;
 | 
					
						
							|  |  |  | FROM: assocs => change-at ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | IN: tools.annotations | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 12:43:32 -04:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | GENERIC: (reset) ( word -- )
 | 
					
						
							| 
									
										
										
										
											2008-04-05 23:59:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 12:43:32 -04:00
										 |  |  | M: generic (reset) | 
					
						
							|  |  |  |     subwords [ (reset) ] each ;
 | 
					
						
							| 
									
										
										
										
											2008-04-05 23:59:31 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 12:43:32 -04:00
										 |  |  | M: word (reset) | 
					
						
							| 
									
										
										
										
											2008-01-05 21:07:13 -05:00
										 |  |  |     dup "unannotated-def" word-prop [ | 
					
						
							| 
									
										
										
										
											2009-07-14 12:43:32 -04:00
										 |  |  |         dup dup "unannotated-def" word-prop define | 
					
						
							| 
									
										
										
										
											2008-02-07 18:07:43 -05:00
										 |  |  |         f "unannotated-def" set-word-prop | 
					
						
							| 
									
										
										
										
											2008-01-05 21:07:13 -05:00
										 |  |  |     ] [ drop ] if ;
 | 
					
						
							| 
									
										
										
										
											2007-12-21 21:18:24 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 12:43:32 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : reset ( word -- )
 | 
					
						
							|  |  |  |     [ (reset) ] with-compilation-unit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  | ERROR: cannot-annotate-twice word ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-27 20:36:52 -04:00
										 |  |  | M: cannot-annotate-twice summary drop "Cannot annotate a word twice" ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-27 17:06:38 -04:00
										 |  |  | PREDICATE: annotated < word "unannotated-def" word-prop >boolean ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : check-annotate-twice ( word -- word )
 | 
					
						
							| 
									
										
										
										
											2012-07-27 17:06:38 -04:00
										 |  |  |     dup annotated? [ cannot-annotate-twice ] when ;
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-26 18:11:50 -04:00
										 |  |  | : annotate-generic ( word quot -- )
 | 
					
						
							|  |  |  |     [ "methods" word-prop values ] dip each ; inline
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : prepare-annotate ( word quot -- word quot quot )
 | 
					
						
							|  |  |  |     [ check-annotate-twice ] dip
 | 
					
						
							|  |  |  |     [ dup def>> 2dup "unannotated-def" set-word-prop ] dip ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 00:35:21 -04:00
										 |  |  | GENERIC# (annotate) 1 ( word quot -- )
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 00:35:21 -04:00
										 |  |  | M: generic (annotate) | 
					
						
							| 
									
										
										
										
											2011-08-26 18:11:50 -04:00
										 |  |  |     '[ _ (annotate) ] annotate-generic ;
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 00:35:21 -04:00
										 |  |  | M: word (annotate) | 
					
						
							| 
									
										
										
										
											2011-08-26 18:11:50 -04:00
										 |  |  |     prepare-annotate | 
					
						
							| 
									
										
										
										
											2009-07-14 00:35:21 -04:00
										 |  |  |     call( old -- new ) define ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-26 12:47:37 -04:00
										 |  |  | GENERIC# (deep-annotate) 1 ( word quot -- )
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | M: generic (deep-annotate) | 
					
						
							| 
									
										
										
										
											2011-08-26 18:11:50 -04:00
										 |  |  |     '[ _ (deep-annotate) ] annotate-generic ;
 | 
					
						
							| 
									
										
										
										
											2011-08-26 12:47:37 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | M: word (deep-annotate) | 
					
						
							| 
									
										
										
										
											2011-08-26 18:11:50 -04:00
										 |  |  |     prepare-annotate | 
					
						
							| 
									
										
										
										
											2011-08-26 12:47:37 -04:00
										 |  |  |     '[ dup callable? [ _ call( old -- new ) ] when ] deep-map define ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-14 00:35:21 -04:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : annotate ( word quot -- )
 | 
					
						
							|  |  |  |     [ (annotate) ] with-compilation-unit ;
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-26 12:47:37 -04:00
										 |  |  | : deep-annotate ( word quot -- )
 | 
					
						
							|  |  |  |     [ (deep-annotate) ] with-compilation-unit ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 23:32:30 -04:00
										 |  |  | :: trace-quot ( word effect quot str -- quot' )
 | 
					
						
							|  |  |  |     effect quot call :> values
 | 
					
						
							|  |  |  |     values length :> n | 
					
						
							|  |  |  |     [ | 
					
						
							| 
									
										
										
										
											2011-10-18 17:30:05 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             "--- " write str write bl word .
 | 
					
						
							|  |  |  |             n ndup n narray values swap zip simple-table. | 
					
						
							|  |  |  |             flush
 | 
					
						
							|  |  |  |         ] with-output>error
 | 
					
						
							| 
									
										
										
										
											2009-07-03 23:32:30 -04:00
										 |  |  |     ] ; inline
 | 
					
						
							| 
									
										
										
										
											2009-05-13 18:03:41 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 23:32:30 -04:00
										 |  |  | MACRO: entering ( word -- quot )
 | 
					
						
							|  |  |  |     dup stack-effect [ in>> ] "Entering" trace-quot ;
 | 
					
						
							| 
									
										
										
										
											2009-05-13 18:03:41 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 23:32:30 -04:00
										 |  |  | MACRO: leaving ( word -- quot )
 | 
					
						
							|  |  |  |     dup stack-effect [ out>> ] "Leaving" trace-quot ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-29 01:37:37 -05:00
										 |  |  | : (watch) ( word def -- def )
 | 
					
						
							|  |  |  |     over '[ _ entering @ _ leaving ] ;
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | : watch ( word -- )
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  |     dup '[ [ _ ] dip (watch) ] annotate ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <PRIVATE
 | 
					
						
							| 
									
										
										
										
											2007-09-20 18:09:08 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-29 01:37:37 -05:00
										 |  |  | : (watch-vars) ( word vars quot -- newquot )
 | 
					
						
							| 
									
										
										
										
											2008-09-13 12:12:36 -04:00
										 |  |  |    '[ | 
					
						
							| 
									
										
										
										
											2011-10-18 17:30:05 -04:00
										 |  |  |         [ | 
					
						
							|  |  |  |             "--- Entering: " write _ .
 | 
					
						
							|  |  |  |             "--- Variable values:" print _ [ dup get ] H{ } map>assoc describe | 
					
						
							|  |  |  |             @ | 
					
						
							|  |  |  |         ] with-output>error
 | 
					
						
							| 
									
										
										
										
											2008-09-13 12:12:36 -04:00
										 |  |  |     ] ;
 | 
					
						
							| 
									
										
										
										
											2008-02-10 02:38:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-06 15:58:52 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-02-10 02:38:51 -05:00
										 |  |  | : watch-vars ( word vars -- )
 | 
					
						
							| 
									
										
										
										
											2008-11-29 01:37:37 -05:00
										 |  |  |     dupd '[ [ _ _ ] dip (watch-vars) ] annotate ;
 | 
					
						
							| 
									
										
										
										
											2008-02-10 02:38:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  | SYMBOL: word-timing | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-02-10 17:16:12 -05:00
										 |  |  | word-timing [ H{ } clone ] initialize
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | : reset-word-timing ( -- )
 | 
					
						
							|  |  |  |     word-timing get clear-assoc ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | <PRIVATE
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  | : (add-timing) ( def word -- def' )
 | 
					
						
							| 
									
										
										
										
											2012-09-20 11:29:37 -04:00
										 |  |  |     '[ | 
					
						
							|  |  |  |         _ benchmark _ word-timing get [ | 
					
						
							|  |  |  |             [ | 
					
						
							|  |  |  |                 [ 0 swap [ + ] change-nth ] keep
 | 
					
						
							|  |  |  |                 [ 1 swap [ 1 + ] change-nth ] keep
 | 
					
						
							|  |  |  |             ] [ 1 2array ] if*
 | 
					
						
							|  |  |  |         ] change-at
 | 
					
						
							|  |  |  |     ] ;
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-06 14:32:07 -05:00
										 |  |  | PRIVATE>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  | : add-timing ( word -- )
 | 
					
						
							|  |  |  |     dup '[ _ (add-timing) ] annotate ;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | : word-timing. ( -- )
 | 
					
						
							| 
									
										
										
										
											2012-09-20 11:29:37 -04:00
										 |  |  |     word-timing get >alist
 | 
					
						
							|  |  |  |     [ second first ] sort-with | 
					
						
							|  |  |  |     [ first2 first2 [ 1,000,000,000 /f ] dip 3array ] map
 | 
					
						
							| 
									
										
										
										
											2008-12-06 01:20:49 -05:00
										 |  |  |     simple-table. ;
 |