本文整理汇总了C#中Expression.ReduceAndCheck方法的典型用法代码示例。如果您正苦于以下问题:C# Expression.ReduceAndCheck方法的具体用法?C# Expression.ReduceAndCheck怎么用?C# Expression.ReduceAndCheck使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Expression
的用法示例。
在下文中一共展示了Expression.ReduceAndCheck方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: RewriteExpression
//.........这里部分代码省略.........
case ExpressionType.Conditional:
result = RewriteConditionalExpression(node, stack);
break;
case ExpressionType.Invoke:
result = RewriteInvocationExpression(node, stack);
break;
case ExpressionType.Lambda:
result = RewriteLambdaExpression(node, stack);
break;
case ExpressionType.ListInit:
result = RewriteListInitExpression(node, stack);
break;
case ExpressionType.MemberAccess:
result = RewriteMemberExpression(node, stack);
break;
case ExpressionType.MemberInit:
result = RewriteMemberInitExpression(node, stack);
break;
case ExpressionType.New:
result = RewriteNewExpression(node, stack);
break;
case ExpressionType.NewArrayInit:
case ExpressionType.NewArrayBounds:
result = RewriteNewArrayExpression(node, stack);
break;
case ExpressionType.TypeEqual:
case ExpressionType.TypeIs:
result = RewriteTypeBinaryExpression(node, stack);
break;
case ExpressionType.Block:
result = RewriteBlockExpression(node, stack);
break;
case ExpressionType.Dynamic:
result = RewriteDynamicExpression(node, stack);
break;
case ExpressionType.Extension:
result = RewriteExtensionExpression(node, stack);
break;
case ExpressionType.Goto:
result = RewriteGotoExpression(node, stack);
break;
case ExpressionType.Index:
result = RewriteIndexExpression(node, stack);
break;
case ExpressionType.Label:
result = RewriteLabelExpression(node, stack);
break;
case ExpressionType.Loop:
result = RewriteLoopExpression(node, stack);
break;
case ExpressionType.Switch:
result = RewriteSwitchExpression(node, stack);
break;
case ExpressionType.Try:
result = RewriteTryExpression(node, stack);
break;
case ExpressionType.AddAssign:
case ExpressionType.AndAssign:
case ExpressionType.DivideAssign:
case ExpressionType.ExclusiveOrAssign:
case ExpressionType.LeftShiftAssign:
case ExpressionType.ModuloAssign:
case ExpressionType.MultiplyAssign:
case ExpressionType.OrAssign:
case ExpressionType.PowerAssign:
case ExpressionType.RightShiftAssign:
case ExpressionType.SubtractAssign:
case ExpressionType.AddAssignChecked:
case ExpressionType.MultiplyAssignChecked:
case ExpressionType.SubtractAssignChecked:
case ExpressionType.PreIncrementAssign:
case ExpressionType.PreDecrementAssign:
case ExpressionType.PostIncrementAssign:
case ExpressionType.PostDecrementAssign:
result = RewriteReducibleExpression(node, stack);
break;
case ExpressionType.Quote:
case ExpressionType.Parameter:
case ExpressionType.Constant:
case ExpressionType.RuntimeVariables:
case ExpressionType.Default:
case ExpressionType.DebugInfo:
result = new Result(RewriteAction.None, node);
break;
default:
result = RewriteExpression(node.ReduceAndCheck(), stack);
if (result.Action == RewriteAction.None)
{
// it's at least Copy because we reduced the node
result = new Result(result.Action | RewriteAction.Copy, result.Node);
}
break;
}
VerifyRewrite(result, node);
return result;
}
示例2: RewriteExpression
//.........这里部分代码省略.........
case ExpressionType.TypeIs:
result = RewriteTypeBinaryExpression(node, stack);
break;
case ExpressionType.Assign:
result = RewriteAssignBinaryExpression(node, stack);
break;
case ExpressionType.Block:
result = RewriteBlockExpression(node, stack);
break;
case ExpressionType.Decrement:
result = RewriteUnaryExpression(node, stack);
break;
case ExpressionType.Dynamic:
result = RewriteDynamicExpression(node, stack);
break;
case ExpressionType.Extension:
result = RewriteExtensionExpression(node, stack);
break;
case ExpressionType.Goto:
result = RewriteGotoExpression(node, stack);
break;
case ExpressionType.Increment:
result = RewriteUnaryExpression(node, stack);
break;
case ExpressionType.Index:
result = RewriteIndexExpression(node, stack);
break;
case ExpressionType.Label:
result = RewriteLabelExpression(node, stack);
break;
case ExpressionType.Loop:
result = RewriteLoopExpression(node, stack);
break;
case ExpressionType.Switch:
result = RewriteSwitchExpression(node, stack);
break;
case ExpressionType.Throw:
result = RewriteThrowUnaryExpression(node, stack);
break;
case ExpressionType.Try:
result = RewriteTryExpression(node, stack);
break;
case ExpressionType.Unbox:
result = RewriteUnaryExpression(node, stack);
break;
case ExpressionType.TypeEqual:
result = RewriteTypeBinaryExpression(node, stack);
break;
case ExpressionType.OnesComplement:
result = RewriteUnaryExpression(node, stack);
break;
case ExpressionType.IsTrue:
result = RewriteUnaryExpression(node, stack);
break;
case ExpressionType.IsFalse:
result = RewriteUnaryExpression(node, stack);
break;
case ExpressionType.AddAssign:
case ExpressionType.AndAssign:
case ExpressionType.DivideAssign:
case ExpressionType.ExclusiveOrAssign:
case ExpressionType.LeftShiftAssign:
case ExpressionType.ModuloAssign:
case ExpressionType.MultiplyAssign:
case ExpressionType.OrAssign:
case ExpressionType.PowerAssign:
case ExpressionType.RightShiftAssign:
case ExpressionType.SubtractAssign:
case ExpressionType.AddAssignChecked:
case ExpressionType.MultiplyAssignChecked:
case ExpressionType.SubtractAssignChecked:
case ExpressionType.PreIncrementAssign:
case ExpressionType.PreDecrementAssign:
case ExpressionType.PostIncrementAssign:
case ExpressionType.PostDecrementAssign:
result = RewriteReducibleExpression(node, stack);
break;
case ExpressionType.Quote:
case ExpressionType.Parameter:
case ExpressionType.Constant:
case ExpressionType.RuntimeVariables:
case ExpressionType.Default:
case ExpressionType.DebugInfo:
return new Result(RewriteAction.None, node);
default:
result = RewriteExpression(node.ReduceAndCheck(), stack);
if (result.Action == RewriteAction.None)
{
// it's at least Copy because we reduced the node
result = new Result(result.Action | RewriteAction.Copy, result.Node);
}
break;
}
VerifyRewrite(result, node);
return result;
}