2008-01-13 04:31:31 -05:00
|
|
|
! Copyright (C) 2007 Chris Double.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
|
|
USING: help.markup help.syntax ;
|
|
|
|
IN: peg
|
|
|
|
|
|
|
|
HELP: parse
|
|
|
|
{ $values
|
|
|
|
{ "input" "a string" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
{ "result" "a parse-result or f" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Given the input string, parse it using the given parser. The result is a <parse-result> object if "
|
2008-03-26 22:50:27 -04:00
|
|
|
"the parse was successful, otherwise it is f." }
|
2008-03-27 07:04:08 -04:00
|
|
|
{ $see-also compile with-packrat packrat-parse } ;
|
2008-03-26 22:50:27 -04:00
|
|
|
|
|
|
|
HELP: with-packrat
|
|
|
|
{ $values
|
|
|
|
{ "quot" "a quotation with stack effect ( input -- result )" }
|
|
|
|
{ "result" "the result of the quotation" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Calls the quotation with a packrat cache in scope. Usually the quotation will "
|
|
|
|
"call " { $link parse } " or call a word produced by " { $link compile } "."
|
|
|
|
"The cache is used to avoid the possible exponential time performace that pegs "
|
2008-03-27 07:04:08 -04:00
|
|
|
"can have, instead giving linear time at the cost of increased memory usage. "
|
|
|
|
"Use of this packrat option also allows direct and indirect recursion to "
|
|
|
|
"be handled in the parser without entering an infinite loop." }
|
|
|
|
{ $see-also compile parse packrat-parse packrat-call } ;
|
|
|
|
|
|
|
|
HELP: packrat-parse
|
|
|
|
{ $values
|
|
|
|
{ "input" "a string" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
{ "result" "a parse-result or f" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Compiles and calls the parser with a packrat cache in scope." }
|
|
|
|
{ $see-also compile parse packrat-call with-packrat } ;
|
|
|
|
|
|
|
|
HELP: packrat-call
|
|
|
|
{ $values
|
|
|
|
{ "input" "a string" }
|
|
|
|
{ "quot" "a quotation with stack effect ( input -- result )" }
|
|
|
|
{ "result" "a parse-result or f" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Calls the compiled parser with a packrat cache in scope." }
|
|
|
|
{ $see-also compile packrat-call packrat-parse with-packrat } ;
|
2008-03-26 22:50:27 -04:00
|
|
|
|
|
|
|
HELP: compile
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
{ "word" "a word" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Compile the parser to a word. The word will have stack effect ( input -- result )."
|
|
|
|
"The mapping from parser to compiled word is kept in a cache. If you later change "
|
|
|
|
"the definition of a parser you'll need to clear this cache with "
|
|
|
|
{ $link reset-compiled-parsers } " before using " { $link compile } " on that parser again." }
|
2008-03-27 07:04:08 -04:00
|
|
|
{ $see-also compile with-packrat reset-compiled-parsers packrat-call packrat-parse } ;
|
2008-03-26 22:50:27 -04:00
|
|
|
|
|
|
|
HELP: reset-compiled-parsers
|
|
|
|
{ $description
|
|
|
|
"Reset the cache mapping parsers to compiled words." } ;
|
2008-01-13 04:31:31 -05:00
|
|
|
|
|
|
|
HELP: token
|
|
|
|
{ $values
|
|
|
|
{ "string" "a string" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that matches the given string." } ;
|
|
|
|
|
|
|
|
HELP: satisfy
|
|
|
|
{ $values
|
|
|
|
{ "quot" "a quotation" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that calls the quotation on the first character of the input string, "
|
|
|
|
"succeeding if that quotation returns true. The AST is the character from the string." } ;
|
|
|
|
|
|
|
|
HELP: range
|
|
|
|
{ $values
|
|
|
|
{ "min" "a character" }
|
|
|
|
{ "max" "a character" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that matches a single character that lies within the range of characters given, inclusive." }
|
|
|
|
{ $examples { $code ": digit ( -- parser ) CHAR: 0 CHAR: 9 range ;" } } ;
|
|
|
|
|
|
|
|
HELP: seq
|
|
|
|
{ $values
|
|
|
|
{ "seq" "a sequence of parsers" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that calls all parsers in the given sequence, in order. The parser succeeds if "
|
|
|
|
"all the parsers succeed, otherwise it fails. The AST produced is a sequence of the AST produced by "
|
|
|
|
"the individual parsers." } ;
|
|
|
|
|
|
|
|
HELP: choice
|
|
|
|
{ $values
|
|
|
|
{ "seq" "a sequence of parsers" }
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that will try all the parsers in the sequence, in order, until one succeeds. "
|
|
|
|
"The resulting AST is that produced by the successful parser." } ;
|
|
|
|
|
|
|
|
HELP: repeat0
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that parses 0 or more instances of the 'p1' parser. The AST produced is "
|
|
|
|
"an array of the AST produced by the 'p1' parser. An empty array indicates 0 instances were "
|
|
|
|
"parsed." } ;
|
|
|
|
|
|
|
|
HELP: repeat1
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that parses 1 or more instances of the 'p1' parser. The AST produced is "
|
|
|
|
"an array of the AST produced by the 'p1' parser." } ;
|
|
|
|
|
|
|
|
HELP: optional
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that parses 0 or 1 instances of the 'p1' parser. The AST produced is "
|
|
|
|
"'f' if 0 instances are parsed the AST produced is 'f', otherwise it is the AST produced by 'p1'." } ;
|
|
|
|
|
|
|
|
HELP: ensure
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that succeeds if the 'p1' parser succeeds but does not add anything to the "
|
|
|
|
"AST and does not move the location in the input string. This can be used for lookahead and "
|
|
|
|
"disambiguation, along with the " { $link ensure-not } " word." }
|
|
|
|
{ $examples { $code "\"0\" token ensure octal-parser" } } ;
|
|
|
|
|
|
|
|
HELP: ensure-not
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that succeeds if the 'p1' parser fails but does not add anything to the "
|
|
|
|
"AST and does not move the location in the input string. This can be used for lookahead and "
|
|
|
|
"disambiguation, along with the " { $link ensure } " word." }
|
|
|
|
{ $code "\"+\" token \"=\" token ensure-not \"+=\" token 3array seq" } ;
|
|
|
|
|
|
|
|
HELP: action
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
{ "quot" "a quotation with stack effect ( ast -- ast )" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that calls the 'p1' parser and applies the quotation to the AST resulting "
|
|
|
|
"from that parse. The result of the quotation is then used as the final AST. This can be used "
|
|
|
|
"for manipulating the parse tree to produce a AST better suited for the task at hand rather than "
|
|
|
|
"the default AST." }
|
|
|
|
{ $code "CHAR: 0 CHAR: 9 range [ to-digit ] action" } ;
|
|
|
|
|
|
|
|
HELP: sp
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that calls the original parser 'p1' after stripping any whitespace "
|
|
|
|
" from the left of the input string." } ;
|
|
|
|
|
|
|
|
HELP: hide
|
|
|
|
{ $values
|
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Returns a parser that succeeds if the original parser succeeds, but does not "
|
|
|
|
"put any result in the AST. Useful for ignoring 'syntax' in the AST." }
|
|
|
|
{ $code "\"[\" token hide number \"]\" token hide 3array seq" } ;
|
|
|
|
|
|
|
|
HELP: delay
|
|
|
|
{ $values
|
2008-03-05 19:15:28 -05:00
|
|
|
{ "quot" "a quotation" }
|
2008-01-13 04:31:31 -05:00
|
|
|
{ "parser" "a parser" }
|
|
|
|
}
|
|
|
|
{ $description
|
|
|
|
"Delays the construction of a parser until it is actually required to parse. This "
|
|
|
|
"allows for calling a parser that results in a recursive call to itself. The quotation "
|
2008-03-05 19:15:28 -05:00
|
|
|
"should return the constructed parser." } ;
|