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"
 |