Equations
Instances For
Equations
Instances For
Maximal (and function application) precedence.
In the standard lean language, no parser has precedence higher than maxPrec.
Note that nothing prevents users from using a higher precedence, but we strongly discourage them from doing it.
Equations
Instances For
Equations
Instances For
Input string and related data. Recall that the FileMap is a helper structure for mapping
String.Pos in the input string to line/column information.
- mk' :: (
- inputString : String
- fileName : String
- fileMap : FileMap
- endPos : String.Pos.Raw
- )
Instances For
Equations
Instances For
Equations
Instances For
Returns true if a specified byte position is greater than or equal to the position which points to
the end of the input string. Otherwise, returns false.
Equations
Instances For
Returns the character at position p of the input string. If p is not a valid position, returns
the fallback value (default : Char), which is 'A', but does not panic.
Equations
Instances For
Returns the character at position p of the input string. Returns (default : Char), which is
'A', if p is not a valid position.
Requires evidence, h, that p is within bounds instead of performing a run-time bounds check as
in InputContext.get.
A typical pattern combines get' with a dependent if-expression to avoid the overhead of an
additional bounds check. For example:
def getInBounds? (s : String) (p : String.Pos) : Option Char :=
if h : s.atEnd p then none else some (s.get' p h)
Even with evidence of ¬ s.atEnd p, p may be invalid if a byte index points into the middle of a
multi-byte UTF-8 character.
Equations
Instances For
Returns the next position in the input string after position p. If p is not a valid position or
p = c.endPos, returns the position one byte after p.
A run-time bounds check is performed to determine whether p is at the end of the string. If a
bounds check has already been performed, use InputContext.next' to avoid a repeated check.
Equations
Instances For
Returns the next position in the input string after position p. The result is unspecified if p
is not a valid position.
Requires evidence, h, that p is within bounds. No run-time bounds check is performed.
Equations
Instances For
Creates a new string that consists of the region of the input string delimited by the two positions.
The result is "" if the start position is greater than or equal to the end position or if the
start position is at the end of the string. If either position is invalid (that is, if either points
at the middle of a multi-byte UTF-8 character) then the result is unspecified.
Equations
Instances For
Extracts a substring of the input string, bounded by startPos and stopPos.
Equations
Instances For
Input context derived from elaboration of previous commands.
- env : Environment
- options : Options
- currNamespace : Name
Instances For
Parser context parts that can be updated without invalidating the parser cache.
- prec : Nat
- quotDepth : Nat
- suppressInsideQuot : Bool
- savedPos? : Option String.Pos.Raw
Instances For
Parser context updateable in adaptUncacheableContextFn.
- tokens : TokenTable
Instances For
Opaque parser context updateable using adaptCacheableContextFn and adaptUncacheableContextFn.
Instances For
Equations
Modifies the ending position of a parser context.
Equations
Instances For
- unexpectedTk : Syntax
If not
missing, used for lazily calculatingunexpectedmessage and range inmkErrorMessage. Otherwise,ParserState.posis used as an empty range. - unexpected : String
Instances For
- startPos : String.Pos.Raw
- stopPos : String.Pos.Raw
- token : Syntax
Instances For
- parserName : Name
- pos : String.Pos.Raw
Instances For
Equations
Instances For
- stx : Syntax
- lhsPrec : Nat
- newPos : String.Pos.Raw
Instances For
- tokenCache : TokenCacheEntry
- parserCache : Std.HashMap ParserCacheKey ParserCacheEntry
Instances For
A syntax array with an inaccessible prefix, used for sound caching.
- raw : Array Lean.Syntax
- drop : Nat
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
- stxStack : SyntaxStack
- lhsPrec : Nat
Set to the precedence of the preceding (not surrounding) parser by
runLongestMatchParserfor the use ofcheckLhsPrecin trailing parsers. Note that with chaining, the preceding parser can be another trailing parser: in1 * 2 + 3, the preceding parser is '*' when '+' is executed. - pos : String.Pos.Raw
- cache : ParserCache
- recoveredErrors : Array (String.Pos.Raw × SyntaxStack × Error)
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Equations
Instances For
Reports given 'expected' messages at range of top stack element (assumed to be a single token).
Replaces the element with missing and resets position to the token position.
iniPos can be specified to avoid this position lookup but still must be identical to the token position.
Equations
Instances For
Reports given 'expected' message at range of top stack element (assumed to be a single token).
Replaces the element with missing and resets position to the token position.
iniPos can be specified to avoid this position lookup but still must be identical to the token position.
Equations
Instances For
Equations
Instances For
Equations
Instances For
- epsilon : FirstTokens
- unknown : FirstTokens
- tokens : List Token → FirstTokens
- optTokens : List Token → FirstTokens
Instances For
Equations
Instances For
Equations
Instances For
- collectKinds : SyntaxNodeKindSet → SyntaxNodeKindSet
- firstTokens : FirstTokens
Instances For
Equations
Instances For
Equations
Instances For
Run p with a fresh cache, restore outer cache afterwards.
p may access the entire syntax stack.
Equations
Instances For
Run p with a fresh cache, restore outer cache afterwards.
p may access the entire syntax stack.
Equations
Instances For
Run p under the given context transformation with a fresh cache (see also withResetCacheFn).
Equations
Instances For
Run p and record result in parser cache for any further invocation with this parserName, parser context, and parser state.
p cannot access syntax stack elements pushed before the invocation in order to make caching independent of parser history.
As this excludes trailing parsers from being cached, we also reset lhsPrec, which is not read but set by leading parsers, to 0
in order to increase cache hits. Finally, errorMsg is also reset to none as a leading parser should not be called in the first
place if there was an error.
Equations
Instances For
Run p and record result in parser cache for any further invocation with this parserName, parser context, and parser state.
p cannot access syntax stack elements pushed before the invocation in order to make caching independent of parser history.
As this excludes trailing parsers from being cached, we also reset lhsPrec, which is not read but set by leading parsers, to 0
in order to increase cache hits. Finally, errorMsg is also reset to none as a leading parser should not be called in the first
place if there was an error.