當前位置: 首頁>>代碼示例>>C#>>正文


C# BinaryExpressionSyntax.Kind方法代碼示例

本文整理匯總了C#中BinaryExpressionSyntax.Kind方法的典型用法代碼示例。如果您正苦於以下問題:C# BinaryExpressionSyntax.Kind方法的具體用法?C# BinaryExpressionSyntax.Kind怎麽用?C# BinaryExpressionSyntax.Kind使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在BinaryExpressionSyntax的用法示例。


在下文中一共展示了BinaryExpressionSyntax.Kind方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: TryFlip

 static bool TryFlip(BinaryExpressionSyntax expr, out SyntaxKind flippedKind, out string operatorText)
 {
     switch (expr.Kind())
     {
         case SyntaxKind.LessThanExpression:
             flippedKind = SyntaxKind.GreaterThanExpression;
             operatorText = ">";
             return true;
         case SyntaxKind.LessThanOrEqualExpression:
             flippedKind = SyntaxKind.GreaterThanOrEqualExpression;
             operatorText = ">=";
             return true;
         case SyntaxKind.GreaterThanExpression:
             flippedKind = SyntaxKind.LessThanExpression;
             operatorText = "<";
             return true;
         case SyntaxKind.GreaterThanOrEqualExpression:
             flippedKind = SyntaxKind.LessThanOrEqualExpression;
             operatorText = "<=";
             return true;
     }
     flippedKind = SyntaxKind.None;
     operatorText = null;
     return false;
 }
開發者ID:alecor191,項目名稱:RefactoringEssentials,代碼行數:25,代碼來源:FlipRelationalOperatorArgumentsCodeRefactoringProvider.cs

示例2: ChangeOperator

 private static BinaryExpressionSyntax ChangeOperator(BinaryExpressionSyntax binary)
 {
     return
         SyntaxFactory.BinaryExpression(
             OppositeExpressionKinds[binary.Kind()],
             binary.Left,
             binary.Right)
         .WithTriviaFrom(binary);
 }
開發者ID:Azzhag,項目名稱:sonarlint-vs,代碼行數:9,代碼來源:BooleanCheckInvertedCodeFixProvider.cs

示例3: VisitBinaryExpression

        public override void VisitBinaryExpression(BinaryExpressionSyntax node)
        {
            node.Left.Accept(this);
            node.Right.Accept(this);

            switch (node.Kind())
            {
                case SyntaxKind.LogicalAndExpression:
                case SyntaxKind.LogicalOrExpression:
                    break;
                default:
                    throw new InvalidPreprocessorExpressionException("Expected logical and/or expression");
            }
        }
開發者ID:transformersprimeabcxyz,項目名稱:_TO-DO-codeformatter-dotnet,代碼行數:14,代碼來源:PreprocessorSymbolTracker.cs

示例4: VisitBinaryExpression

        public override SyntaxNode VisitBinaryExpression(BinaryExpressionSyntax node)
        {
            Tristate leftState = _expressionEvaluator.EvaluateExpression(node.Left);
            Tristate rightState = _expressionEvaluator.EvaluateExpression(node.Right);

            var left = (ExpressionSyntax)node.Left.Accept(this);
            var right = (ExpressionSyntax)node.Right.Accept(this);

            if (node.Left != left)
            {
                node = node.WithLeft(left);
            }

            if (node.Right != right)
            {
                node = node.WithRight(right);
            }

            if (leftState != Tristate.Varying && rightState != Tristate.Varying)
            {
                return node;
            }

            ExpressionSyntax newExpression = null;

            if (node.Kind() == SyntaxKind.LogicalAndExpression)
            {
                if (leftState == Tristate.True)
                {
                    // true && varying == varying
                    newExpression = right;
                }
                else if (rightState == Tristate.True)
                {
                    // varying && true == varying
                    newExpression = left;
                }
            }
            else if (node.Kind() == SyntaxKind.LogicalOrExpression)
            {
                if (leftState == Tristate.False)
                {
                    // false || varying == varying
                    newExpression = right;
                }
                else if (rightState == Tristate.False)
                {
                    // varying || false == varying
                    newExpression = left;
                }
            }

            if (newExpression != null)
            {
                return newExpression
                    .WithLeadingTrivia(node.GetLeadingTrivia())
                    .WithTrailingTrivia(node.GetTrailingTrivia());
            }

            return node;
        }
開發者ID:transformersprimeabcxyz,項目名稱:_TO-DO-codeformatter-dotnet,代碼行數:61,代碼來源:PreprocessorExpressionSimplifier.cs

示例5: VisitBinaryExpression

            public override SyntaxNode VisitBinaryExpression(BinaryExpressionSyntax node)
            {
                _cancellationToken.ThrowIfCancellationRequested();

                // Special case: We parenthesize to avoid a situation where inlining an
                // expression can cause code to parse differently. The canonical case is...
                //
                //     var x = 0;
                //     var y = (1 + 2);
                //     var z = new[] { x < x, x > y };
                //
                // Inlining 'y' in the code above will produce code that parses differently
                // (i.e. as a generic method invocation).
                //
                //      var z = new[] { x < x, x > (1 + 2) };

                var result = (BinaryExpressionSyntax)base.VisitBinaryExpression(node);

                if ((node.Kind() == SyntaxKind.GreaterThanExpression || node.Kind() == SyntaxKind.RightShiftExpression) && !node.IsParentKind(SyntaxKind.ParenthesizedExpression))
                {
                    return result.Parenthesize();
                }

                return result;
            }
開發者ID:RoryVL,項目名稱:roslyn,代碼行數:25,代碼來源:CSharpSimplificationService.Expander.cs

示例6: TryGenerateBinaryOperation

        private bool TryGenerateBinaryOperation(BinaryExpressionSyntax binaryExpression)
        {
            BinaryOperatorKind kind;
            switch (binaryExpression.Kind())
            {
                case SyntaxKind.AddExpression:
                    kind = BinaryOperatorKind.Plus;
                    break;
                case SyntaxKind.BitwiseOrExpression:
                    kind = BinaryOperatorKind.BitwiseOr;
                    break;
                case SyntaxKind.BitwiseAndExpression:
                    kind = BinaryOperatorKind.BitwiseAnd;
                    break;
                default:
                    return false;
            }

            using (BinaryOperationTag(kind))
            {
                return TryGenerateExpression(binaryExpression.Left)
                    && TryGenerateExpression(binaryExpression.Right);
            }
        }
開發者ID:ehsansajjad465,項目名稱:roslyn,代碼行數:24,代碼來源:MethodXmlBuilder.cs

示例7: VisitBinaryExpression

 public override bool VisitBinaryExpression(BinaryExpressionSyntax node)
 {
     switch (node.Kind())
     {
         case SyntaxKind.LogicalAndExpression:
         case SyntaxKind.LogicalOrExpression:
             return Visit(node.Left);
     }
     return base.VisitBinaryExpression(node);
 }
開發者ID:ceddlyburge,項目名稱:RefactoringEssentials,代碼行數:10,代碼來源:FunctionNeverReturnsAnalyzer.cs

示例8: AnalyzeComparisonWithFlags

        static bool AnalyzeComparisonWithFlags(BinaryExpressionSyntax boP, out ExpressionSyntax flagsExpression, out ExpressionSyntax targetExpression, out bool testFlagset)
        {
            var left = boP.Left.SkipParens();
            var right = boP.Right.SkipParens();

            testFlagset = boP.Kind() != SyntaxKind.EqualsExpression;
            flagsExpression = targetExpression = null;

            BinaryExpressionSyntax primExp;

            if (left.IsKind(SyntaxKind.BitwiseAndExpression))
            {
                primExp = left as BinaryExpressionSyntax;
                flagsExpression = right;
            }
            else
            {
                primExp = right as BinaryExpressionSyntax;
                flagsExpression = left;
            }

            if (primExp == null)
                return false;

            if (primExp.Left.IsEquivalentTo(flagsExpression))
            {
                DecomposeBinaryOperator(primExp, out flagsExpression, out targetExpression);
                return true;
            }

            if (primExp.Right.IsEquivalentTo(flagsExpression))
            {
                DecomposeBinaryOperator(primExp, out flagsExpression, out targetExpression);
                return true;
            }

            return false;
        }
開發者ID:alecor191,項目名稱:RefactoringEssentials,代碼行數:38,代碼來源:ConvertBitwiseFlagComparisonToHasFlagsCodeRefactoringProvider.cs

示例9: AnalyzeComparisonWithNull

        static bool AnalyzeComparisonWithNull(BinaryExpressionSyntax boP, out ExpressionSyntax flagsExpression, out ExpressionSyntax targetExpression, out bool testFlagset)
        {
            var left = boP.Left.SkipParens();
            var right = boP.Right.SkipParens();
            testFlagset = boP.Kind() == SyntaxKind.EqualsExpression;
            flagsExpression = targetExpression = null;

            ExpressionSyntax primExp;
            BinaryExpressionSyntax binOp;
            if (left.IsKind(SyntaxKind.NumericLiteralExpression))
            {
                primExp = left;
                binOp = right as BinaryExpressionSyntax;
            }
            else
            {
                primExp = right;
                binOp = left as BinaryExpressionSyntax;
            }

            if (binOp == null)
            {
                return false;
            }

            DecomposeBinaryOperator(binOp, out flagsExpression, out targetExpression);
            return primExp != null && primExp.ToString() == "0";
        }
開發者ID:alecor191,項目名稱:RefactoringEssentials,代碼行數:28,代碼來源:ConvertBitwiseFlagComparisonToHasFlagsCodeRefactoringProvider.cs

示例10: VisitBinaryExpression

            public override SyntaxNode VisitBinaryExpression(BinaryExpressionSyntax node)
            {
                bool isOrAsNode = node.Kind() == SyntaxKind.AsExpression || node.Kind() == SyntaxKind.IsExpression;

                var result = (ExpressionSyntax)base.VisitBinaryExpression(node);

                if (result != node && isOrAsNode)
                {
                    // In order to handle cases in which simplifying a name would result in code
                    // that parses different, we pre-emptively add parentheses that will be
                    // simplified away later.
                    //
                    // For example, this code...
                    //
                    //     var x = y as Nullable<int> + 1;
                    //
                    // ...should simplify as...
                    //
                    //     var x = (y as int?) + 1;
                    return result.Parenthesize().WithAdditionalAnnotations(Formatter.Annotation);
                }

                return result;
            }
開發者ID:Rickinio,項目名稱:roslyn,代碼行數:24,代碼來源:CSharpNameReducer.Rewriter.cs

示例11: IsComparisonOfZeroAndSomethingNeverLessThanZero

        private bool IsComparisonOfZeroAndSomethingNeverLessThanZero(BinaryExpressionSyntax binaryExpression, SemanticModel semanticModel, CancellationToken cancellationToken)
        {
            var canSimplify = false;

            if (binaryExpression.Kind() == SyntaxKind.GreaterThanExpression &&
                binaryExpression.Right.Kind() == SyntaxKind.NumericLiteralExpression)
            {
                canSimplify = CanSimplifyToLengthEqualsZeroExpression(
                    binaryExpression.Left,
                    (LiteralExpressionSyntax)binaryExpression.Right,
                    semanticModel,
                    cancellationToken);
            }
            else if (binaryExpression.Kind() == SyntaxKind.LessThanExpression &&
                     binaryExpression.Left.Kind() == SyntaxKind.NumericLiteralExpression)
            {
                canSimplify = CanSimplifyToLengthEqualsZeroExpression(
                    binaryExpression.Right,
                    (LiteralExpressionSyntax)binaryExpression.Left,
                    semanticModel,
                    cancellationToken);
            }
            else if (binaryExpression.Kind() == SyntaxKind.EqualsExpression &&
                     binaryExpression.Right.Kind() == SyntaxKind.NumericLiteralExpression)
            {
                canSimplify = CanSimplifyToLengthEqualsZeroExpression(
                    binaryExpression.Left,
                    (LiteralExpressionSyntax)binaryExpression.Right,
                    semanticModel,
                    cancellationToken);
            }
            else if (binaryExpression.Kind() == SyntaxKind.EqualsExpression &&
                     binaryExpression.Left.Kind() == SyntaxKind.NumericLiteralExpression)
            {
                canSimplify = CanSimplifyToLengthEqualsZeroExpression(
                    binaryExpression.Right,
                    (LiteralExpressionSyntax)binaryExpression.Left,
                    semanticModel,
                    cancellationToken);
            }

            return canSimplify;
        }
開發者ID:RoryVL,項目名稱:roslyn,代碼行數:43,代碼來源:InvertIfCodeRefactoringProvider.cs

示例12: BindSimpleBinaryOperator

        private BoundExpression BindSimpleBinaryOperator(BinaryExpressionSyntax node, DiagnosticBag diagnostics)
        {
            // The simple binary operators are left-associative, and expressions of the form
            // a + b + c + d .... are relatively common in machine-generated code. The parser can handle
            // creating a deep-on-the-left syntax tree no problem, and then we promptly blow the stack during
            // semantic analysis. Here we build an explicit stack to handle the left-hand recursion.

            Debug.Assert(IsSimpleBinaryOperator(node.Kind()));

            var syntaxNodes = ArrayBuilder<BinaryExpressionSyntax>.GetInstance();

            ExpressionSyntax current = node;
            while (IsSimpleBinaryOperator(current.Kind()))
            {
                var binOp = (BinaryExpressionSyntax)current;
                syntaxNodes.Push(binOp);
                current = binOp.Left;
            }

            int compoundStringLength = 0;

            BoundExpression result = BindExpression(current, diagnostics);

            if (node.IsKind(SyntaxKind.SubtractExpression)
                && current.IsKind(SyntaxKind.ParenthesizedExpression))
            {
                if (result.Kind == BoundKind.TypeExpression
                    && !((ParenthesizedExpressionSyntax)current).Expression.IsKind(SyntaxKind.ParenthesizedExpression))
                {
                    Error(diagnostics, ErrorCode.ERR_PossibleBadNegCast, node);
                }
                else if (result.Kind == BoundKind.BadExpression)
                {
                    var parenthesizedExpression = (ParenthesizedExpressionSyntax) current;

                    if (parenthesizedExpression.Expression.IsKind(SyntaxKind.IdentifierName)
                        && ((IdentifierNameSyntax) parenthesizedExpression.Expression).Identifier.ValueText == "dynamic")
                    {
                        Error(diagnostics, ErrorCode.ERR_PossibleBadNegCast, node);
                    }
                }
            }

            while (syntaxNodes.Count > 0)
            {
                BinaryExpressionSyntax syntaxNode = syntaxNodes.Pop();
                BindValueKind bindValueKind = GetBinaryAssignmentKind(syntaxNode.Kind());
                BoundExpression left = CheckValue(result, bindValueKind, diagnostics);
                BoundExpression right = BindValue(syntaxNode.Right, diagnostics, BindValueKind.RValue);
                BoundExpression boundOp = BindSimpleBinaryOperator(syntaxNode, diagnostics, left, right, ref compoundStringLength);
                result = boundOp;
            }

            syntaxNodes.Free();
            return result;
        }
開發者ID:TyOverby,項目名稱:roslyn,代碼行數:56,代碼來源:Binder_Operators.cs


注:本文中的BinaryExpressionSyntax.Kind方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。