93 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Factor
		
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Factor
		
	
	
| ! Copyright (C) 2008 Joe Groff.
 | |
| ! See http://factorcode.org/license.txt for BSD license.
 | |
| USING: help.markup help.syntax kernel multiline sequences ;
 | |
| IN: literals
 | |
| 
 | |
| HELP: $
 | |
| { $syntax "$ word" }
 | |
| { $description "Executes " { $snippet "word" } " at parse time and adds the result(s) to the parser accumulator." }
 | |
| { $notes { $snippet "word" } "'s definition is looked up and " { $link call } "ed at parse time, so words that reference words in the current compilation unit cannot be used with " { $snippet "$" } "." }
 | |
| { $examples
 | |
|     { $example
 | |
|         "USING: kernel literals prettyprint ;"
 | |
|         "IN: scratchpad"
 | |
|         ""
 | |
|         "CONSTANT: five 5"
 | |
|         "{ $ five } ."
 | |
|         "{ 5 }"
 | |
|     }
 | |
|     { $example
 | |
|         "USING: kernel literals prettyprint ;"
 | |
|         "IN: scratchpad"
 | |
|         ""
 | |
|         ": seven-eleven ( -- a b ) 7 11 ;"
 | |
|         "{ $ seven-eleven } ."
 | |
|         "{ 7 11 }"
 | |
|     }
 | |
| } ;
 | |
| 
 | |
| HELP: $[
 | |
| { $syntax "$[ code ]" }
 | |
| { $description "Calls " { $snippet "code" } " at parse time and adds the result(s) to the parser accumulator." }
 | |
| { $notes "Since " { $snippet "code" } " is " { $link call } "ed at parse time, it cannot reference any words defined in the same compilation unit." }
 | |
| { $examples
 | |
|     { $example
 | |
|         "USING: kernel literals math prettyprint ;"
 | |
|         "IN: scratchpad"
 | |
|         ""
 | |
|         "<< CONSTANT: five 5 >>"
 | |
|         "{ $[ five dup 1 + dup 2 + ] } ."
 | |
|         "{ 5 6 8 }"
 | |
|     }
 | |
| } ;
 | |
| 
 | |
| HELP: ${
 | |
| { $syntax "${ code }" }
 | |
| { $description "Outputs an array containing the results of executing " { $snippet "code" } " at parse time." }
 | |
| { $notes { $snippet "code" } "'s definition is looked up and " { $link call } "ed at parse time, so words that reference words in the current compilation unit cannot be used with " { $snippet "$" } "." }
 | |
| { $examples
 | |
|     { $example
 | |
|         "USING: kernel literals math prettyprint ;"
 | |
|         "IN: scratchpad"
 | |
|         ""
 | |
|         "CONSTANT: five 5"
 | |
|         "CONSTANT: six 6"
 | |
|         "${ five six 7 } ."
 | |
|         "{ 5 6 7 }"
 | |
|     }
 | |
| } ;
 | |
| 
 | |
| { postpone: $ postpone: $[ postpone: ${ } related-words
 | |
| 
 | |
| HELP: flags{
 | |
| { $values { "values" sequence } }
 | |
| { $description "Constructs a constant flag value from a sequence of integers or words that output integers. The resulting constant is computed at parse-time, which makes this word as efficient as using a literal integer." }
 | |
| { $examples
 | |
|     { $example
 | |
|         "USING: literals kernel prettyprint ;"
 | |
|         "IN: scratchpad"
 | |
|         "CONSTANT: x 0x1"
 | |
|         "flags{ 0x20 x 0b100 } .h"
 | |
|         "0x25"
 | |
|     }
 | |
| } ;
 | |
| 
 | |
| 
 | |
| ARTICLE: "literals" "Interpolating code results into literal values"
 | |
| "The " { $vocab-link "literals" } " vocabulary contains words to run code at parse time and insert the results into more complex literal values."
 | |
| { $example
 | |
|     "USING: kernel literals math prettyprint ;"
 | |
|     "IN: scratchpad"
 | |
|     ""
 | |
|     "<< CONSTANT: five 5 >>"
 | |
|     "{ $ five $[ five dup 1 + dup 2 + ] } ."
 | |
|     "{ 5 5 6 8 }"
 | |
| }
 | |
| { $subsections
 | |
|     postpone: $
 | |
|     postpone: $[
 | |
|     postpone: ${
 | |
| } ;
 | |
| 
 | |
| ABOUT: "literals"
 |