2008-09-05 20:01:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								USING:  help.markup  help.syntax  words  parser  quotations  strings  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								system sequences ;
 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-20 18:09:08 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								IN:  tools.annotations  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ARTICLE: "tools.annotations"  "Word annotations" 
							 
						 
					
						
							
								
									
										
										
										
											2007-12-21 21:18:24 -05:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								"The word annotation feature modifies word definitions to add debugging code. You can restore the old definition by calling "  { $link reset } " on the word in question."  
						 
					
						
							
								
									
										
										
										
											2008-12-06 01:20:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								$nl
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								"Printing messages when a word is called or returns:"  
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    watch
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    watch-vars
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2008-12-06 01:20:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								"Timing words:"  
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    reset-word-timing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    add-timing
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    word-timing.
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								}
							 
						 
					
						
							
								
									
										
										
										
											2007-09-20 18:09:08 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								"All of the above words are implemented using a single combinator which applies a quotation to a word definition to yield a new definition:"  
						 
					
						
							
								
									
										
										
										
											2009-10-01 15:56:36 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $subsections annotate }
							 
						 
					
						
							
								
									
										
										
										
											2009-09-08 21:49:12 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $warning
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    "Certain internal words, such as words in the "  { $vocab-link "math"  } ", "  { $vocab-link "sequences"  } " and UI vocabularies, cannot be annotated, since the annotated code may end up recursively invoking the word in question. This may crash or hang Factor. It is safest to only define annotations on your own words." 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								} ;
 
							 
						 
					
						
							
								
									
										
										
										
											2007-09-20 18:09:08 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								ABOUT: "tools.annotations" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  annotate  
						 
					
						
							
								
									
										
										
										
											2014-05-23 23:20:15 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $values { "word"  word } { "quot"  { $quotation (  old-def  --  new-def  )  } } }
							 
						 
					
						
							
								
									
										
										
										
											2007-09-20 18:09:08 -04:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								{ $description "Changes a word definition to the result of applying a quotation to the old definition."  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $notes "This word is used to implement "  { $link watch } "."  } ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  watch  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "word"  word } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Annotates a word definition to print the data stack on entry and exit."  } ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-09-05 20:01:39 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ watch watch-vars reset } related-words
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  reset  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     { "word"  word } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Resets any annotations on a word."  }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $notes "This word will remove a "  { $link watch } "."  } ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  watch-vars  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								     { "word"  word } { "vars"  "a sequence of symbols"  } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Annotates a word definition to print the "  { $snippet "vars"  } " upon entering the word. This word is useful for debugging."  } ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2008-12-06 01:20:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								HELP:  add-timing  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $values { "word"  word } }
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Adds timing code to a word, which records its total running time, including that of words it calls, on every invocation."  }
							 
						 
					
						
							
								
									
										
										
										
											2011-11-10 15:32:43 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $see-also "timing"  "tools.profiler.sampling"  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2008-12-06 01:20:49 -05:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  reset-word-timing  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Resets the word timing table."  } ;
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  word-timing.  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								{ $description "Prints the word timing table."  } ;
 
							 
						 
					
						
							
								
									
										
										
										
											2009-07-28 07:49:03 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								HELP:  cannot-annotate-twice  
						 
					
						
							
								
									
										
										
										
											2011-10-31 23:00:51 -04:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								{ $error-description "Thrown when attempting to annotate a word that's already been annotated. If a word already has an annotation such as a watch or a breakpoint, you must first "  { $link reset } " the word before adding another annotation."  } ;