当前位置: 首页>>代码示例>>C#>>正文


C# ParsingContext.AddTrace方法代码示例

本文整理汇总了C#中ParsingContext.AddTrace方法的典型用法代码示例。如果您正苦于以下问题:C# ParsingContext.AddTrace方法的具体用法?C# ParsingContext.AddTrace怎么用?C# ParsingContext.AddTrace使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ParsingContext的用法示例。


在下文中一共展示了ParsingContext.AddTrace方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: 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;
     }
 }
开发者ID:HyperSharp,项目名称:Hyperspace.DotLua,代码行数:24,代码来源:ErrorRecoveryParserAction.cs

示例2: 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);
        }
开发者ID:HyperSharp,项目名称:Hyperspace.DotLua,代码行数:39,代码来源:ReduceParserActions.cs

示例3: 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. 
            var 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
            }
        } //method
开发者ID:HyperSharp,项目名称:Hyperspace.DotLua,代码行数:45,代码来源:ErrorRecoveryParserAction.cs


注:本文中的ParsingContext.AddTrace方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。