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


C# ILExpression.GetSelfAndChildrenRecursive方法代碼示例

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


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

示例1: TransformExpression

		AstNode TransformExpression(ILExpression expr)
		{
			AstNode node = TransformByteCode(expr);
			Expression astExpr = node as Expression;
			
			// get IL ranges - used in debugger
			List<ILRange> ilRanges = ILRange.OrderAndJoint(expr.GetSelfAndChildrenRecursive<ILExpression>().SelectMany(e => e.ILRanges));
			AstNode result;
			
			if (astExpr != null)
				result = Convert(astExpr, expr.InferredType, expr.ExpectedType);
			else
				result = node;
			
			if (result != null)
				return result.WithAnnotation(ilRanges);
			
			return result;
		}
開發者ID:JustasB,項目名稱:cudafy,代碼行數:19,代碼來源:AstMethodBodyBuilder.cs

示例2: IsSafeForInlineOver

		/// <summary>
		/// Determines whether it is safe to move 'expressionBeingMoved' past 'expr'
		/// </summary>
		bool IsSafeForInlineOver(ILExpression expr, ILExpression expressionBeingMoved)
		{
			switch (expr.Code) {
				case ILCode.Ldloc:
					ILVariable loadedVar = (ILVariable)expr.Operand;
					if (numLdloca.GetOrDefault(loadedVar) != 0) {
						// abort, inlining is not possible
						return false;
					}
					foreach (ILExpression potentialStore in expressionBeingMoved.GetSelfAndChildrenRecursive<ILExpression>(list_ILExpression)) {
						if (potentialStore.Code == ILCode.Stloc && potentialStore.Operand == loadedVar)
							return false;
					}
					// the expression is loading a non-forbidden variable
					return true;
				case ILCode.Ldloca:
				case ILCode.Ldflda:
				case ILCode.Ldsflda:
				case ILCode.Ldelema:
				case ILCode.AddressOf:
				case ILCode.ValueOf:
				case ILCode.NullableOf:
					// address-loading instructions are safe if their arguments are safe
					foreach (ILExpression arg in expr.Arguments) {
						if (!IsSafeForInlineOver(arg, expressionBeingMoved))
							return false;
					}
					return true;
				default:
					// instructions with no side-effects are safe (except for Ldloc and Ldloca which are handled separately)
					return expr.HasNoSideEffects();
			}
		}
開發者ID:GreenDamTan,項目名稱:dnSpy,代碼行數:36,代碼來源:ILInlining.cs

示例3: SetResult

 static void SetResult(ILExpression expr, ILExpression n)
 {
     // IL ranges from removed nodes are assigned to the new operator expression
     var removednodes = expr.GetSelfAndChildrenRecursive<ILExpression>().Except(n.GetSelfAndChildrenRecursive<ILExpression>());
     n.ILRanges.AddRange(removednodes.SelectMany(el => el.ILRanges));
     // the new expression is wrapped in a container so that negations aren't pushed through lifted comparison operations
     expr.Code = ILCode.Wrap;
     expr.Arguments.Clear();
     expr.Arguments.Add(n);
     expr.ILRanges.Clear();
     expr.InferredType = n.InferredType;
 }
開發者ID:ropean,項目名稱:Usable,代碼行數:12,代碼來源:LiftedOperators.cs

示例4: IsSafeForInlineOver

		/// <summary>
		/// Determines whether it is save to move 'expressionBeingMoved' past 'expr'
		/// </summary>
		bool IsSafeForInlineOver(ILExpression expr, ILExpression expressionBeingMoved)
		{
			switch (expr.Code) {
				case ILCode.Ldloc:
					ILVariable loadedVar = (ILVariable)expr.Operand;
					if (numLdloca.GetOrDefault(loadedVar) != 0) {
						// abort, inlining is not possible
						return false;
					}
					foreach (ILExpression potentialStore in expressionBeingMoved.GetSelfAndChildrenRecursive().OfType<ILExpression>()) {
						if (potentialStore.Code == ILCode.Stloc && potentialStore.Operand == loadedVar)
							return false;
					}
					// the expression is loading a non-forbidden variable
					return true;
				case ILCode.Ldloca:
				case ILCode.Ldflda:
				case ILCode.Ldsflda:
				case ILCode.Ldelema:
					// address-loading instructions are safe if their arguments are safe
					foreach (ILExpression arg in expr.Arguments) {
						if (!IsSafeForInlineOver(arg, expressionBeingMoved))
							return false;
					}
					return true;
				default:
					// abort, inlining is not possible
					return false;
			}
		}
開發者ID:BGCX261,項目名稱:zoom-decompiler-hg-to-git,代碼行數:33,代碼來源:ILInlining.cs


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