@Override
@RuleDependency(recognizer=GrammarParser.class, rule=GrammarParser.RULE_ruleSpec, version=0, dependents=Dependents.SELF)
public void parse(ParserTaskManager taskManager, ParseContext context, DocumentSnapshot snapshot, Collection<? extends ParserDataDefinition<?>> requestedData, ParserResultHandler results)
throws InterruptedException, ExecutionException {
if (requestedData.contains(GrammarParserDataDefinitions.CURRENT_RULE_CONTEXT)) {
CurrentRuleContextData data = null;
if (context.getPosition() != null) {
int caretOffset = context.getPosition().getOffset();
Future<ParserData<List<Anchor>>> result =
taskManager.getData(snapshot, GrammarParserDataDefinitions.DYNAMIC_ANCHOR_POINTS, EnumSet.of(ParserDataOptions.SYNCHRONOUS));
ParserData<List<Anchor>> anchorsData = result.get();
List<Anchor> anchors = anchorsData.getData();
GrammarParser.RuleSpecContext ruleContext = null;
int grammarType = -1;
Future<ParserData<FileModel>> fileModelResult =
taskManager.getData(snapshot, GrammarParserDataDefinitions.FILE_MODEL, EnumSet.of(ParserDataOptions.ALLOW_STALE, ParserDataOptions.SYNCHRONOUS));
ParserData<FileModel> fileModelData = fileModelResult.get();
FileModel fileModel = fileModelData.getData();
if (anchors != null) {
Anchor enclosing = null;
/*
* parse the current rule
*/
for (Anchor anchor : anchors) {
if (anchor instanceof GrammarParserAnchorListener.GrammarTypeAnchor) {
grammarType = ((GrammarParserAnchorListener.GrammarTypeAnchor)anchor).getGrammarType();
continue;
}
if (anchor.getSpan().getStartPosition(snapshot).getOffset() <= caretOffset && anchor.getSpan().getEndPosition(snapshot).getOffset() > caretOffset) {
enclosing = anchor;
} else if (anchor.getSpan().getStartPosition(snapshot).getOffset() > caretOffset) {
break;
}
}
if (enclosing != null) {
CharStream input = new DocumentSnapshotCharStream(snapshot);
input.seek(enclosing.getSpan().getStartPosition(snapshot).getOffset());
GrammarLexer lexer = new GrammarLexer(input);
CommonTokenStream tokens = new TaskTokenStream(lexer);
GrammarParser parser = GrammarParserFactory.DEFAULT.getParser(tokens);
try {
parser.getInterpreter().setPredictionMode(PredictionMode.SLL);
parser.removeErrorListeners();
parser.setBuildParseTree(true);
parser.setErrorHandler(new BailErrorStrategy());
ruleContext = parser.ruleSpec();
} catch (ParseCancellationException ex) {
if (ex.getCause() instanceof RecognitionException) {
// retry with default error handler
tokens.reset();
parser.getInterpreter().setPredictionMode(PredictionMode.LL);
parser.setInputStream(tokens);
parser.setErrorHandler(new DefaultErrorStrategy());
ruleContext = parser.ruleSpec();
} else {
throw ex;
}
}
}
}
data = new CurrentRuleContextData(snapshot, grammarType, fileModel, ruleContext);
}
results.addResult(new BaseParserData<>(context, GrammarParserDataDefinitions.CURRENT_RULE_CONTEXT, snapshot, data));
}
}
CurrentRuleContextParserTask.java 文件源码
java
阅读 22
收藏 0
点赞 0
评论 0
项目:antlrworks2
作者:
评论列表
文章目录