Comments (5)
Is there an ANTLR bug involved? This appears to be a unit test for another application which uses ANTLR but isn't testing the ANTLR library itself. The expectedTokens
test doesn't contain any assertions, so it's unclear what the intent actually is.
from antlr4.
Tried to clarify the code a bit, please re-check. The test concerned is expectedTokens().
Unfortunately, the stuff lies in the output to stdout. I spit out what I have parsed so far and then what tokens are to be expected using Parser#getExpectedTokens(). All I see as the expected token is the token I just parsed.
Maybe I just do not grok how this is supposed to work.
from antlr4.
Parser.getExpectedTokens()
uses the current state of the current context (parser._ctx.s
) determine the set of expected tokens. As soon as the parser changes state, the set of expected tokens changes. Right before a call to match
(which produces the call to visitTerminal
), the state is set to the source state of the non-epsilon transition matching the symbol. If you call getExpectedTokens()
from within visitTerminal
of a parser listener, you'll get the set of tokens for the single transition that matched the terminal (which is exactly what you saw).
from antlr4.
Hey, Sam, thanks for being patient with me. I actually mixed up stuff here and what you say makes sense. For I actually want to do: Finding out the set of valid tokens that can follow on a given position inside a buffer. Like for an editor with auto-completion. Any pointers?
from antlr4.
In ANTLRWorks 2 (currently closed source due to licensing details I'm working on), to get this information I needed to extend ParserATNSimulator
, CommonToken
, ANTLRErrorStrategy
, TokenSource
, and use a special RuntimeException
to bail out of the internals while preserving the interpreter state, as well as controlling the beast with a special controller. In addition, I had to add the -Xforce-atn
option to the tool (and use it for any parser where I intend to derive this information).
It's gruesome, but what's possible here is without a doubt the most powerful solution to this problem I've ever seen. Proof of this should be clear in what I was able to accomplish in GoWorks in under 1 month.
from antlr4.
Related Issues (20)
- PL/SQL grammar cannot recognise identifiers that start with keywords HOT 2
- Migration bug in golang runtime HOT 5
- Could not deserialize ATN with version 3 (expected 4) with Hibernate 6 HOT 3
- Tool does not generate any constants for channels for the TypeScript target HOT 5
- Generate an abstract class/interface for rule containing only other parser rules as unnamed subrules
- [Swift] Add privacy manifest HOT 2
- [Go] Type signature error HOT 1
- How can we write multiple parsers to use the same lexer? HOT 1
- [CSharp] Member GetMaxTokenType missing in IVocabulary
- Missing TypeScript methods
- [TorqueScript: C++]Old scripting language conversion HOT 2
- When is there a plan to support Rust?
- Left recursive rules that do not conform to a pattern ANTLR can handle HOT 1
- Android Tool run
- Separated package/artifactId when the minor version is upgraded for compatibility issues
- [Go] Can not use BailErrorStrategy since ParseCancellationException is not implement HOT 2
- Issue with using ANTLR4 from Julia via PyCall
- [TypeScript target] I would like to know how to create a custom visitor in TypeScript. HOT 4
- C++ warning + fix HOT 2
- Error with books source examples in chapter 4
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from antlr4.