本文整理汇总了C#中BinaryOperatorKind.IsLogical方法的典型用法代码示例。如果您正苦于以下问题:C# BinaryOperatorKind.IsLogical方法的具体用法?C# BinaryOperatorKind.IsLogical怎么用?C# BinaryOperatorKind.IsLogical使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类BinaryOperatorKind
的用法示例。
在下文中一共展示了BinaryOperatorKind.IsLogical方法的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: MakeBinaryOperator
private BoundExpression MakeBinaryOperator(
BoundBinaryOperator oldNode,
CSharpSyntaxNode syntax,
BinaryOperatorKind operatorKind,
BoundExpression loweredLeft,
BoundExpression loweredRight,
TypeSymbol type,
MethodSymbol method,
bool isPointerElementAccess = false,
bool isCompoundAssignment = false,
BoundUnaryOperator applyParentUnaryOperator = null)
{
Debug.Assert(oldNode == null || (oldNode.Syntax == syntax));
if (_inExpressionLambda)
{
switch (operatorKind.Operator() | operatorKind.OperandTypes())
{
case BinaryOperatorKind.ObjectAndStringConcatenation:
case BinaryOperatorKind.StringAndObjectConcatenation:
case BinaryOperatorKind.StringConcatenation:
return RewriteStringConcatenation(syntax, operatorKind, loweredLeft, loweredRight, type);
case BinaryOperatorKind.DelegateCombination:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__Combine);
case BinaryOperatorKind.DelegateRemoval:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__Remove);
case BinaryOperatorKind.DelegateEqual:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__op_Equality);
case BinaryOperatorKind.DelegateNotEqual:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__op_Inequality);
}
}
else
// try to lower the expression.
{
if (operatorKind.IsDynamic())
{
Debug.Assert(!isPointerElementAccess);
if (operatorKind.IsLogical())
{
return MakeDynamicLogicalBinaryOperator(syntax, operatorKind, loweredLeft, loweredRight, method, type, isCompoundAssignment, applyParentUnaryOperator);
}
else
{
Debug.Assert((object)method == null);
return _dynamicFactory.MakeDynamicBinaryOperator(operatorKind, loweredLeft, loweredRight, isCompoundAssignment, type).ToExpression();
}
}
if (operatorKind.IsLifted())
{
return RewriteLiftedBinaryOperator(syntax, operatorKind, loweredLeft, loweredRight, type, method);
}
if (operatorKind.IsUserDefined())
{
return LowerUserDefinedBinaryOperator(syntax, operatorKind, loweredLeft, loweredRight, type, method);
}
switch (operatorKind.OperatorWithLogical() | operatorKind.OperandTypes())
{
case BinaryOperatorKind.NullableNullEqual:
case BinaryOperatorKind.NullableNullNotEqual:
return RewriteNullableNullEquality(syntax, operatorKind, loweredLeft, loweredRight, type);
case BinaryOperatorKind.ObjectAndStringConcatenation:
case BinaryOperatorKind.StringAndObjectConcatenation:
case BinaryOperatorKind.StringConcatenation:
return RewriteStringConcatenation(syntax, operatorKind, loweredLeft, loweredRight, type);
case BinaryOperatorKind.StringEqual:
return RewriteStringEquality(oldNode, syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_String__op_Equality);
case BinaryOperatorKind.StringNotEqual:
return RewriteStringEquality(oldNode, syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_String__op_Inequality);
case BinaryOperatorKind.DelegateCombination:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__Combine);
case BinaryOperatorKind.DelegateRemoval:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__Remove);
case BinaryOperatorKind.DelegateEqual:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__op_Equality);
case BinaryOperatorKind.DelegateNotEqual:
return RewriteDelegateOperation(syntax, operatorKind, loweredLeft, loweredRight, type, SpecialMember.System_Delegate__op_Inequality);
case BinaryOperatorKind.LogicalBoolAnd:
if (loweredRight.ConstantValue == ConstantValue.True) return loweredLeft;
if (loweredLeft.ConstantValue == ConstantValue.True) return loweredRight;
if (loweredLeft.ConstantValue == ConstantValue.False) return loweredLeft;
if (loweredRight.Kind == BoundKind.Local || loweredRight.Kind == BoundKind.Parameter)
{
operatorKind &= ~BinaryOperatorKind.Logical;
}
goto default;
//.........这里部分代码省略.........
示例2: LowerUserDefinedBinaryOperator
private BoundExpression LowerUserDefinedBinaryOperator(
CSharpSyntaxNode syntax,
BinaryOperatorKind operatorKind,
BoundExpression loweredLeft,
BoundExpression loweredRight,
TypeSymbol type,
MethodSymbol method)
{
Debug.Assert(!operatorKind.IsLogical());
if (operatorKind.IsLifted())
{
return RewriteLiftedBinaryOperator(syntax, operatorKind, loweredLeft, loweredRight, type, method);
}
// Otherwise, nothing special here.
Debug.Assert((object)method != null);
Debug.Assert(method.ReturnType == type);
return BoundCall.Synthesized(syntax, null, method, loweredLeft, loweredRight);
}
示例3: BindDynamicBinaryOperator
private BoundExpression BindDynamicBinaryOperator(
BinaryExpressionSyntax node,
BinaryOperatorKind kind,
BoundExpression left,
BoundExpression right,
DiagnosticBag diagnostics)
{
// This method binds binary * / % + - << >> < > <= >= == != & ! ^ && || operators where one or both
// of the operands are dynamic.
Debug.Assert((object)left.Type != null && left.Type.IsDynamic() || (object)right.Type != null && right.Type.IsDynamic());
bool hasError = false;
bool leftValidOperand = IsLegalDynamicOperand(left);
bool rightValidOperand = IsLegalDynamicOperand(right);
if (!leftValidOperand || !rightValidOperand)
{
// Operator '{0}' cannot be applied to operands of type '{1}' and '{2}'
Error(diagnostics, ErrorCode.ERR_BadBinaryOps, node, node.OperatorToken.Text, left.Display, right.Display);
hasError = true;
}
MethodSymbol userDefinedOperator = null;
if (kind.IsLogical() && leftValidOperand)
{
// We need to make sure left is either implicitly convertible to Boolean or has user defined truth operator.
// left && right is lowered to {op_False|op_Implicit}(left) ? left : And(left, right)
// left || right is lowered to {op_True|!op_Implicit}(left) ? left : Or(left, right)
HashSet<DiagnosticInfo> useSiteDiagnostics = null;
if (!IsValidDynamicCondition(left, isNegative: kind == BinaryOperatorKind.LogicalAnd, useSiteDiagnostics: ref useSiteDiagnostics, userDefinedOperator: out userDefinedOperator))
{
// Dev11 reports ERR_MustHaveOpTF. The error was shared between this case and user-defined binary Boolean operators.
// We report two distinct more specific error messages.
Error(diagnostics, ErrorCode.ERR_InvalidDynamicCondition, node.Left, left.Type, kind == BinaryOperatorKind.LogicalAnd ? "false" : "true");
hasError = true;
}
diagnostics.Add(node, useSiteDiagnostics);
}
return new BoundBinaryOperator(
syntax: node,
operatorKind: (hasError ? kind : kind.WithType(BinaryOperatorKind.Dynamic)).WithOverflowChecksIfApplicable(CheckOverflowAtRuntime),
left: left,
right: right,
constantValueOpt: ConstantValue.NotAvailable,
methodOpt: userDefinedOperator,
resultKind: LookupResultKind.Viable,
type: Compilation.DynamicType,
hasErrors: hasError);
}
示例4: GetBinaryOperatorName
private string GetBinaryOperatorName(BinaryOperatorKind opKind, out bool isChecked, out bool isLifted, out bool requiresLifted)
{
isChecked = opKind.IsChecked();
isLifted = opKind.IsLifted();
requiresLifted = opKind.IsComparison();
switch (opKind.Operator())
{
case BinaryOperatorKind.Addition: return isChecked ? "AddChecked" : "Add";
case BinaryOperatorKind.Multiplication: return isChecked ? "MultiplyChecked" : "Multiply";
case BinaryOperatorKind.Subtraction: return isChecked ? "SubtractChecked" : "Subtract";
case BinaryOperatorKind.Division: return "Divide";
case BinaryOperatorKind.Remainder: return "Modulo";
case BinaryOperatorKind.And: return opKind.IsLogical() ? "AndAlso" : "And";
case BinaryOperatorKind.Xor: return "ExclusiveOr";
case BinaryOperatorKind.Or: return opKind.IsLogical() ? "OrElse" : "Or";
case BinaryOperatorKind.LeftShift: return "LeftShift";
case BinaryOperatorKind.RightShift: return "RightShift";
case BinaryOperatorKind.Equal: return "Equal";
case BinaryOperatorKind.NotEqual: return "NotEqual";
case BinaryOperatorKind.LessThan: return "LessThan";
case BinaryOperatorKind.LessThanOrEqual: return "LessThanOrEqual";
case BinaryOperatorKind.GreaterThan: return "GreaterThan";
case BinaryOperatorKind.GreaterThanOrEqual: return "GreaterThanOrEqual";
default:
throw ExceptionUtilities.UnexpectedValue(opKind.Operator());
}
}
示例5: BoundUserDefinedConditionalLogicalOperator
public BoundUserDefinedConditionalLogicalOperator(
CSharpSyntaxNode syntax,
BinaryOperatorKind operatorKind,
BoundExpression left,
BoundExpression right,
MethodSymbol logicalOperator,
MethodSymbol trueOperator,
MethodSymbol falseOperator,
LookupResultKind resultKind,
ImmutableArray<MethodSymbol> originalUserDefinedOperatorsOpt,
TypeSymbol type,
bool hasErrors = false)
: this(
syntax,
operatorKind,
left,
right,
logicalOperator,
trueOperator,
falseOperator,
resultKind,
type,
hasErrors)
{
Debug.Assert(operatorKind.IsUserDefined() && operatorKind.IsLogical());
this.OriginalUserDefinedOperatorsOpt = originalUserDefinedOperatorsOpt;
}
示例6: GetSimpleBuiltInOperators
//.........这里部分代码省略.........
}).AsImmutableOrNull(),
(new []
{
GetSignature(BinaryOperatorKind.IntLessThan),
GetSignature(BinaryOperatorKind.UIntLessThan),
GetSignature(BinaryOperatorKind.LongLessThan),
GetSignature(BinaryOperatorKind.ULongLessThan),
GetSignature(BinaryOperatorKind.FloatLessThan),
GetSignature(BinaryOperatorKind.DoubleLessThan),
GetSignature(BinaryOperatorKind.DecimalLessThan),
GetSignature(BinaryOperatorKind.LiftedIntLessThan),
GetSignature(BinaryOperatorKind.LiftedUIntLessThan),
GetSignature(BinaryOperatorKind.LiftedLongLessThan),
GetSignature(BinaryOperatorKind.LiftedULongLessThan),
GetSignature(BinaryOperatorKind.LiftedFloatLessThan),
GetSignature(BinaryOperatorKind.LiftedDoubleLessThan),
GetSignature(BinaryOperatorKind.LiftedDecimalLessThan),
}).AsImmutableOrNull(),
(new []
{
GetSignature(BinaryOperatorKind.IntGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.UIntGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LongGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.ULongGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.FloatGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.DoubleGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.DecimalGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedIntGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedUIntGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedLongGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedULongGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedFloatGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedDoubleGreaterThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedDecimalGreaterThanOrEqual),
}).AsImmutableOrNull(),
(new []
{
GetSignature(BinaryOperatorKind.IntLessThanOrEqual),
GetSignature(BinaryOperatorKind.UIntLessThanOrEqual),
GetSignature(BinaryOperatorKind.LongLessThanOrEqual),
GetSignature(BinaryOperatorKind.ULongLessThanOrEqual),
GetSignature(BinaryOperatorKind.FloatLessThanOrEqual),
GetSignature(BinaryOperatorKind.DoubleLessThanOrEqual),
GetSignature(BinaryOperatorKind.DecimalLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedIntLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedUIntLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedLongLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedULongLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedFloatLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedDoubleLessThanOrEqual),
GetSignature(BinaryOperatorKind.LiftedDecimalLessThanOrEqual),
}).AsImmutableOrNull(),
(new []
{
GetSignature(BinaryOperatorKind.IntAnd),
GetSignature(BinaryOperatorKind.UIntAnd),
GetSignature(BinaryOperatorKind.LongAnd),
GetSignature(BinaryOperatorKind.ULongAnd),
GetSignature(BinaryOperatorKind.BoolAnd),
GetSignature(BinaryOperatorKind.LiftedIntAnd),
GetSignature(BinaryOperatorKind.LiftedUIntAnd),
GetSignature(BinaryOperatorKind.LiftedLongAnd),
GetSignature(BinaryOperatorKind.LiftedULongAnd),
GetSignature(BinaryOperatorKind.LiftedBoolAnd),
}).AsImmutableOrNull(),
(new []
{
GetSignature(BinaryOperatorKind.IntXor),
GetSignature(BinaryOperatorKind.UIntXor),
GetSignature(BinaryOperatorKind.LongXor),
GetSignature(BinaryOperatorKind.ULongXor),
GetSignature(BinaryOperatorKind.BoolXor),
GetSignature(BinaryOperatorKind.LiftedIntXor),
GetSignature(BinaryOperatorKind.LiftedUIntXor),
GetSignature(BinaryOperatorKind.LiftedLongXor),
GetSignature(BinaryOperatorKind.LiftedULongXor),
GetSignature(BinaryOperatorKind.LiftedBoolXor),
}).AsImmutableOrNull(),
(new []
{
GetSignature(BinaryOperatorKind.IntOr),
GetSignature(BinaryOperatorKind.UIntOr),
GetSignature(BinaryOperatorKind.LongOr),
GetSignature(BinaryOperatorKind.ULongOr),
GetSignature(BinaryOperatorKind.BoolOr),
GetSignature(BinaryOperatorKind.LiftedIntOr),
GetSignature(BinaryOperatorKind.LiftedUIntOr),
GetSignature(BinaryOperatorKind.LiftedLongOr),
GetSignature(BinaryOperatorKind.LiftedULongOr),
GetSignature(BinaryOperatorKind.LiftedBoolOr),
}).AsImmutableOrNull(),
};
var allOperators = new[] { nonLogicalOperators, logicalOperators };
Interlocked.CompareExchange(ref builtInOperators, allOperators, null);
}
operators.AddRange(builtInOperators[kind.IsLogical() ? 1 : 0][kind.OperatorIndex()]);
}
示例7: OpKind
public static BinaryOperatorKind OpKind(BinaryOperatorKind kind, TypeSymbol left, TypeSymbol right)
{
int? leftIndex = TypeToIndex(left);
if (leftIndex == null)
{
return BinaryOperatorKind.Error;
}
int? rightIndex = TypeToIndex(right);
if (rightIndex == null)
{
return BinaryOperatorKind.Error;
}
var result = BinaryOperatorKind.Error;
// kind.OperatorIndex() collapses '&' and '&&' (and '|' and '||'). To correct
// this problem, we handle kinds satisfying IsLogical() separately. Fortunately,
// such operators only work on boolean types, so there's no need to write out
// a whole new table.
//
// Example: int & int is legal, but int && int is not, so we can't use the same
// table for both operators.
if (!kind.IsLogical() || (leftIndex == (int)BinaryOperatorKind.Bool && rightIndex == (int)BinaryOperatorKind.Bool))
{
result = opkind[kind.OperatorIndex()][leftIndex.Value, rightIndex.Value];
}
return result == BinaryOperatorKind.Error ? result : result | kind;
}
示例8: MakeDynamicBinaryOperator
internal LoweredDynamicOperation MakeDynamicBinaryOperator(
BinaryOperatorKind operatorKind,
BoundExpression loweredLeft,
BoundExpression loweredRight,
bool isCompoundAssignment,
TypeSymbol resultType)
{
Debug.Assert(operatorKind.IsDynamic());
_factory.Syntax = loweredLeft.Syntax;
CSharpBinderFlags binderFlags = 0;
if (operatorKind.IsChecked())
{
binderFlags |= CSharpBinderFlags.CheckedContext;
}
if (operatorKind.IsLogical())
{
binderFlags |= CSharpBinderFlags.BinaryOperationLogical;
}
var loweredArguments = ImmutableArray.Create<BoundExpression>(loweredLeft, loweredRight);
MethodSymbol argumentInfoFactory = GetArgumentInfoFactory();
var binderConstruction = ((object)argumentInfoFactory != null) ? MakeBinderConstruction(WellKnownMember.Microsoft_CSharp_RuntimeBinder_Binder__BinaryOperation, new[]
{
// flags:
_factory.Literal((int)binderFlags),
// expression type:
_factory.Literal((int)operatorKind.ToExpressionType(isCompoundAssignment)),
// context:
_factory.TypeofDynamicOperationContextType(),
// argument infos:
MakeCallSiteArgumentInfos(argumentInfoFactory, loweredArguments)
}) : null;
return MakeDynamicOperation(binderConstruction, null, RefKind.None, loweredArguments, ImmutableArray<RefKind>.Empty, null, resultType);
}
示例9: LowerUserDefinedBinaryOperator
private BoundExpression LowerUserDefinedBinaryOperator(
CSharpSyntaxNode syntax,
BinaryOperatorKind operatorKind,
BoundExpression loweredLeft,
BoundExpression loweredRight,
TypeSymbol type,
MethodSymbol method)
{
if (operatorKind.IsLogical())
{
// Yes, we could have a lifted, logical, user-defined operator:
//
// struct C {
// public static C operator &(C x, C y) {...}
// public static bool operator true(C? c) { ... }
// public static bool operator false(C? c) { ... }
// }
//
// If we have C? q, r and we say q && r then this gets bound as
// C? tempQ = q ;
// C.false(tempQ) ?
// tempQ :
// (
// C? tempR = r ;
// tempQ.HasValue & tempR.HasValue ?
// new C?(C.&(tempQ.GetValueOrDefault(), tempR.GetValueOrDefault())) :
// default C?()
// )
//
// Note that the native compiler does not allow q && r. However, the native compiler
// *does* allow q && r if C is defined as:
//
// struct C {
// public static C? operator &(C? x, C? y) {...}
// public static bool operator true(C? c) { ... }
// public static bool operator false(C? c) { ... }
// }
//
// It seems unusual and wrong that an & operator should be allowed to become
// a && operator if there is a "manually lifted" operator in source, but not
// if there is a "synthesized" lifted operator. Roslyn fixes this bug.
//
// Anyway, in this case we must lower this to its non-logical form, and then
// lower the interior of that to its non-lifted form.
return LowerUserDefinedLogicalOperator(syntax, operatorKind, loweredLeft, loweredRight, type, method);
}
else if (operatorKind.IsLifted())
{
if (operatorKind.IsComparison())
{
return LowerLiftedUserDefinedComparisonOperator(syntax, operatorKind, loweredLeft, loweredRight, method);
}
else
{
return LowerLiftedBinaryArithmeticOperator(syntax, operatorKind, loweredLeft, loweredRight, type, method);
}
}
// Otherwise, nothing special here.
Debug.Assert((object)method != null);
Debug.Assert(method.ReturnType == type);
return BoundCall.Synthesized(syntax, null, method, loweredLeft, loweredRight);
}