本文整理汇总了C#中Irony.Parsing.ParsingContext.AddTrace方法的典型用法代码示例。如果您正苦于以下问题:C# ParsingContext.AddTrace方法的具体用法?C# ParsingContext.AddTrace怎么用?C# ParsingContext.AddTrace使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Irony.Parsing.ParsingContext
的用法示例。
在下文中一共展示了ParsingContext.AddTrace方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: CompleteReduce
//Completes reduce: pops child nodes from the stack and pushes result node into the stack
protected void CompleteReduce(ParsingContext context) {
var resultNode = context.CurrentParserInput;
var childCount = Production.RValues.Count;
//Pop stack
context.ParserStack.Pop(childCount);
//Copy comment block from first child; if comments precede child node, they precede the parent as well.
if (resultNode.ChildNodes.Count > 0)
resultNode.Comments = resultNode.ChildNodes[0].Comments;
//Inherit precedence and associativity, to cover a standard case: BinOp->+|-|*|/;
// BinOp node should inherit precedence from underlying operator symbol.
//TODO: this special case will be handled differently. A ToTerm method should be expanded to allow "combined" terms like "NOT LIKE".
// OLD COMMENT: A special case is SQL operator "NOT LIKE" which consists of 2 tokens. We therefore inherit "max" precedence from any children
if (Production.LValue.Flags.IsSet(TermFlags.InheritPrecedence))
InheritPrecedence(resultNode);
//Push new node into stack and move to new state
//First read the state from top of the stack
context.CurrentParserState = context.ParserStack.Top.State;
if (context.TracingEnabled)
context.AddTrace(Resources.MsgTracePoppedState, Production.LValue.Name);
#region comments on special case
//Special case: if a non-terminal is Transient (ex: BinOp), then result node is not this NonTerminal, but its its child (ex: symbol).
// Shift action will invoke OnShifting on actual term being shifted (symbol); we need to invoke Shifting even on NonTerminal itself
// - this would be more expected behavior in general. ImpliedPrecHint relies on this
#endregion
if (resultNode.Term != Production.LValue) //special case
Production.LValue.OnShifting(context.SharedParsingEventArgs);
// Shift to new state - execute shift over the non-terminal of the production.
var shift = context.CurrentParserState.Actions[Production.LValue];
// Execute shift to new state
shift.Execute(context);
//Invoke Reduce event
Production.LValue.OnReduced(context, Production, resultNode);
}
示例2: Execute
public override void Execute(ParsingContext context) {
context.Status = ParserStatus.Error;
var grammar = context.Language.Grammar;
grammar.ReportParseError(context);
// Do not recover if we're already at EOF, or if we're in command line mode
if (context.CurrentParserInput.Term == grammar.Eof || context.Mode == ParseMode.CommandLine)
return;
//Try to recover from error
context.Status = ParserStatus.Recovering;
context.AddTrace(Resources.MsgTraceRecovering); // *** RECOVERING - searching for state with error shift ***
var recovered = TryRecoverFromError(context);
if (recovered) {
context.AddTrace(Resources.MsgTraceRecoverSuccess); //add new trace entry
context.Status = ParserStatus.Parsing;
} else {
context.AddTrace(Resources.MsgTraceRecoverFailed);
context.Status = ParserStatus.Error;
}
}
示例3: Execute
public override void Execute(ParsingContext context) {
if (context.TracingEnabled)
context.AddTrace(Resources.MsgTraceExecCustomAction);
//States with DefaultAction do NOT read input, so we read it here
if (context.CurrentParserInput == null)
context.Parser.ReadInput();
// Remember old state and input; if they don't change after custom action - it is error, we may fall into an endless loop
var oldState = context.CurrentParserState;
var oldInput = context.CurrentParserInput;
ExecuteRef(context, this);
//Prevent from falling into an infinite loop
if (context.CurrentParserState == oldState && context.CurrentParserInput == oldInput) {
context.AddParserError(Resources.MsgErrorCustomActionDidNotAdvance);
context.Parser.RecoverFromError();
}
}//method
示例4: TryRecoverFromError
protected bool TryRecoverFromError(ParsingContext context)
{
var grammar = context.Language.Grammar;
var parser = context.Parser;
//1. We need to find a state in the stack that has a shift item based on error production (with error token),
// and error terminal is current. This state would have a shift action on error token.
ParserAction errorShiftAction = FindErrorShiftActionInStack(context);
if (errorShiftAction == null) return false; //we failed to recover
context.AddTrace(Resources.MsgTraceRecoverFoundState, context.CurrentParserState);
//2. Shift error token - execute shift action
context.AddTrace(Resources.MsgTraceRecoverShiftError, errorShiftAction);
errorShiftAction.Execute(context);
//4. Now we need to go along error production until the end, shifting tokens that CAN be shifted and ignoring others.
// We shift until we can reduce
context.AddTrace(Resources.MsgTraceRecoverShiftTillEnd);
while (true) {
if (context.CurrentParserInput == null)
parser.ReadInput();
if (context.CurrentParserInput.Term == grammar.Eof)
return false;
//Check if we can reduce
var nextAction = parser.GetNextAction();
if (nextAction == null) {
parser.ReadInput();
continue;
}
if (nextAction is ReduceParserAction) {
//We are reducing a fragment containing error - this is the end of recovery
//Clear all input token queues and buffered input, reset location back to input position token queues;
context.SetSourceLocation(context.CurrentParserInput.Span.Location);
//Reduce error production - it creates parent non-terminal that "hides" error inside
context.AddTrace(Resources.MsgTraceRecoverReducing);
context.AddTrace(Resources.MsgTraceRecoverAction, nextAction);
nextAction.Execute(context); //execute reduce
return true; //we recovered
}
// If it is not reduce, simply execute it (it is most likely shift)
context.AddTrace(Resources.MsgTraceRecoverAction, nextAction);
nextAction.Execute(context); //shift input token
}
}