Equations
- Lean.Parser.mkAtom info val = Lean.Syntax.atom info val
Equations
- Lean.Parser.mkIdent info rawVal val = Lean.Syntax.ident info rawVal val []
Return character after position pos
Equations
- Lean.Parser.getNext input pos = input.get (input.next pos)
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
- Lean.Parser.maxPrec = 1024
Equations
- s.insert k = Lean.PersistentHashMap.insert s k ()
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.
Instances For
Equations
- Lean.Parser.instInhabitedInputContext = { default := { input := default, fileName := default, fileMap := default } }
Input context derived from elaboration of previous commands.
- env : Environment
- options : Options
- currNamespace : Name
Parser context parts that can be updated without invalidating the parser cache.
- prec : Nat
- quotDepth : Nat
- suppressInsideQuot : Bool
- savedPos? : Option String.Pos
Instances For
Parser context updateable in adaptUncacheableContextFn
.
- tokens : TokenTable
Opaque parser context updateable using adaptCacheableContextFn
and adaptUncacheableContextFn
.
- unexpectedTk : Syntax
If not
missing
, used for lazily calculatingunexpected
message and range inmkErrorMessage
. Otherwise,ParserState.pos
is used as an empty range. - unexpected : String
Equations
- Lean.Parser.instInhabitedError = { default := { unexpectedTk := default, unexpected := default, expected := default } }
Equations
- Lean.Parser.instBEqError = { beq := Lean.Parser.beqError✝ }
Equations
- One or more equations did not get rendered due to their size.
Equations
- Lean.Parser.Error.instToString = { toString := Lean.Parser.Error.toString }
Equations
- One or more equations did not get rendered due to their size.
- startPos : String.Pos
- stopPos : String.Pos
- token : Syntax
- parserName : Name
- pos : String.Pos
Equations
Equations
- Lean.Parser.instHashableParserCacheKey = { hash := fun (k : Lean.Parser.ParserCacheKey) => hash (k.pos, k.parserName) }
- stx : Syntax
- lhsPrec : Nat
- newPos : String.Pos
- tokenCache : TokenCacheEntry
- parserCache : Std.HashMap ParserCacheKey ParserCacheEntry
Equations
- Lean.Parser.initCacheForInput input = { tokenCache := { startPos := input.endPos + ' ' }, parserCache := ∅ }
A syntax array with an inaccessible prefix, used for sound caching.
- raw : Array Lean.Syntax
- drop : Nat
Instances For
Equations
- stack.toSubarray = (Lean.Parser.SyntaxStack.raw✝ stack).toSubarray (Lean.Parser.SyntaxStack.drop✝ stack)
Equations
- Lean.Parser.SyntaxStack.empty = { raw := #[], drop := 0 }
Equations
- stack.size = (Lean.Parser.SyntaxStack.raw✝ stack).size - Lean.Parser.SyntaxStack.drop✝ stack
Equations
- stack.shrink n = { raw := (Lean.Parser.SyntaxStack.raw✝ stack).shrink (Lean.Parser.SyntaxStack.drop✝ stack + n), drop := Lean.Parser.SyntaxStack.drop✝ stack }
Equations
- stack.push a = { raw := (Lean.Parser.SyntaxStack.raw✝ stack).push a, drop := Lean.Parser.SyntaxStack.drop✝ stack }
Equations
- stack.pop = if stack.size > 0 then { raw := (Lean.Parser.SyntaxStack.raw✝ stack).pop, drop := Lean.Parser.SyntaxStack.drop✝ stack } else stack
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- stack.extract start stop = (Lean.Parser.SyntaxStack.raw✝ stack).extract (Lean.Parser.SyntaxStack.drop✝ stack + start) (Lean.Parser.SyntaxStack.drop✝ stack + stop)
Equations
- One or more equations did not get rendered due to their size.
- stxStack : SyntaxStack
- lhsPrec : Nat
Set to the precedence of the preceding (not surrounding) parser by
runLongestMatchParser
for the use ofcheckLhsPrec
in 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
- cache : ParserCache
- recoveredErrors : Array (String.Pos × SyntaxStack × Error)
Equations
- s.pushSyntax n = { stxStack := s.stxStack.push n, lhsPrec := s.lhsPrec, pos := s.pos, cache := s.cache, errorMsg := s.errorMsg, recoveredErrors := s.recoveredErrors }
Equations
- s.shrinkStack iniStackSz = { stxStack := s.stxStack.shrink iniStackSz, lhsPrec := s.lhsPrec, pos := s.pos, cache := s.cache, errorMsg := s.errorMsg, recoveredErrors := s.recoveredErrors }
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- One or more equations did not get rendered due to their size.
Equations
- s.mkError msg = (s.setError { expected := [msg] }).pushSyntax Lean.Syntax.missing
Equations
- One or more equations did not get rendered due to their size.
Equations
- s.mkEOIError expected = s.mkUnexpectedError "unexpected end of input" expected
Equations
- One or more equations did not get rendered due to their size.
Equations
- s.mkErrorAt msg pos initStackSz? = s.mkErrorsAt [msg] pos initStackSz?
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
- One or more equations did not get rendered due to their size.
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
- s.mkUnexpectedTokenError msg iniPos = s.mkUnexpectedTokenErrors [msg] iniPos
Equations
- s.mkUnexpectedErrorAt msg pos = (s.setPos pos).mkUnexpectedError msg
Equations
- One or more equations did not get rendered due to their size.
Equations
- Lean.Parser.instInhabitedParserFn = { default := fun (x : Lean.Parser.ParserContext) (s : Lean.Parser.ParserState) => s }
- epsilon : FirstTokens
- unknown : FirstTokens
- tokens : List Token → FirstTokens
- optTokens : List Token → FirstTokens
Equations
- Lean.Parser.instInhabitedFirstTokens = { default := Lean.Parser.FirstTokens.epsilon }
Equations
- Lean.Parser.FirstTokens.epsilon.seq x✝ = x✝
- (Lean.Parser.FirstTokens.optTokens s₁).seq (Lean.Parser.FirstTokens.optTokens s₂) = Lean.Parser.FirstTokens.optTokens (s₁ ++ s₂)
- (Lean.Parser.FirstTokens.optTokens s₁).seq (Lean.Parser.FirstTokens.tokens s₂) = Lean.Parser.FirstTokens.tokens (s₁ ++ s₂)
- x✝¹.seq x✝ = x✝¹
Equations
Equations
- Lean.Parser.FirstTokens.epsilon.merge x✝ = x✝.toOptional
- x.merge Lean.Parser.FirstTokens.epsilon = x.toOptional
- (Lean.Parser.FirstTokens.tokens s₁).merge (Lean.Parser.FirstTokens.tokens s₂) = Lean.Parser.FirstTokens.tokens (s₁ ++ s₂)
- (Lean.Parser.FirstTokens.optTokens s₁).merge (Lean.Parser.FirstTokens.optTokens s₂) = Lean.Parser.FirstTokens.optTokens (s₁ ++ s₂)
- (Lean.Parser.FirstTokens.tokens s₁).merge (Lean.Parser.FirstTokens.optTokens s₂) = Lean.Parser.FirstTokens.optTokens (s₁ ++ s₂)
- (Lean.Parser.FirstTokens.optTokens s₁).merge (Lean.Parser.FirstTokens.tokens s₂) = Lean.Parser.FirstTokens.optTokens (s₁ ++ s₂)
- x✝¹.merge x✝ = Lean.Parser.FirstTokens.unknown
Equations
- Lean.Parser.FirstTokens.epsilon.toStr = "epsilon"
- Lean.Parser.FirstTokens.unknown.toStr = "unknown"
- (Lean.Parser.FirstTokens.tokens tks).toStr = toString tks
- (Lean.Parser.FirstTokens.optTokens tks).toStr = "?" ++ toString tks
Equations
- Lean.Parser.FirstTokens.instToString = { toString := Lean.Parser.FirstTokens.toStr }
- collectKinds : SyntaxNodeKindSet → SyntaxNodeKindSet
- firstTokens : FirstTokens
Instances For
Equations
- Lean.Parser.instInhabitedParserInfo = { default := { collectTokens := default, collectKinds := default, firstTokens := default } }
Equations
- Lean.Parser.instInhabitedParser = { default := { info := default, fn := default } }
Equations
- One or more equations did not get rendered due to their size.
Run p
with a fresh cache, restore outer cache afterwards.
p
may access the entire syntax stack.
Equations
- One or more equations did not get rendered due to their size.
Run p
with a fresh cache, restore outer cache afterwards.
p
may access the entire syntax stack.
Run p
under the given context transformation with a fresh cache (see also withResetCacheFn
).
Equations
- One or more equations did not get rendered due to their size.
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
- One or more equations did not get rendered due to their size.
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
- Lean.Parser.withCache parserName = Lean.Parser.withFn (Lean.Parser.withCacheFn parserName)