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


C# Cecil.MethodDefinition類代碼示例

本文整理匯總了C#中Mono.Cecil.MethodDefinition的典型用法代碼示例。如果您正苦於以下問題:C# MethodDefinition類的具體用法?C# MethodDefinition怎麽用?C# MethodDefinition使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MethodDefinition類屬於Mono.Cecil命名空間,在下文中一共展示了MethodDefinition類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: SwapParameterTypes

        private static void SwapParameterTypes(MethodDefinition method,
            TypeDefinition targetDependency,
            TypeReference interfaceType,
            HashSet<MethodReference> modifiedMethods)
        {
            if (method.IsAbstract || !method.HasBody)
                return;

            bool modified = false;
            var parameters = method.Parameters.Cast<ParameterDefinition>();
            foreach (var parameter in parameters)
            {
                var parameterType = parameter.ParameterType;
                if (parameterType != targetDependency)
                    continue;

                parameter.ParameterType = interfaceType;
                modified = true;
            }

            if (!modified)
                return;

            modifiedMethods.Add(method);
        }
開發者ID:philiplaureano,項目名稱:Taiji,代碼行數:25,代碼來源:SwapEmbeddedMethodTypeReferences.cs

示例2: MemberIsCalled

		private bool MemberIsCalled (TypeDefinition type, MethodDefinition method)
		{
			bool isCalled = false;
			
			if (TypeIsInternal (type) && TypeIsPrivate (type) && MemberIsInternal (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (TypeIsInternal (type) && TypeIsPrivate (type) && MemberIsPrivate (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (TypeIsInternal (type) && !TypeIsPrivate (type) && MemberIsInternal (method))
				isCalled = InternalMemberIsCalled (method);
			if (TypeIsInternal (type) && !TypeIsPrivate (type) && MemberIsPrivate (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (!TypeIsInternal (type) && TypeIsPrivate (type) && MemberIsInternal (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (!TypeIsInternal (type) && TypeIsPrivate (type) && MemberIsPrivate (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (!TypeIsInternal (type) && !TypeIsPrivate (type) && MemberIsInternal (method))
			    isCalled = InternalMemberIsCalled (method);
			if (!TypeIsInternal (type) && !TypeIsPrivate (type) && MemberIsPrivate (method))
			    isCalled = PrivateMemberIsCalled (type, method);
			if (TypeIsInternal (type) && TypeIsPrivate (type) && !MemberIsInternal (method) && !MemberIsPrivate (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (TypeIsInternal (type) && !TypeIsPrivate (type) && !MemberIsInternal (method) && !MemberIsPrivate (method))
				isCalled = InternalMemberIsCalled (method);
			if (!TypeIsInternal (type) && TypeIsPrivate (type) && !MemberIsInternal (method) && !MemberIsPrivate (method))
				isCalled = PrivateMemberIsCalled (type, method);
			if (!TypeIsInternal (type) && !TypeIsPrivate (type) && !MemberIsInternal (method) && !MemberIsPrivate (method))  
			    isCalled = true;
			}
開發者ID:JianwenSun,項目名稱:mono-soc-2007,代碼行數:29,代碼來源:AvoidUncalledPrivateCodeRule.cs

示例3: CreateDefaultCtor

            /// <summary>
            /// Create the Ctor
            /// </summary>
            private static void CreateDefaultCtor(ReachableContext reachableContext, TypeDefinition type)
            {
                var typeSystem = type.Module.TypeSystem;
                var ctor = new MethodDefinition(".ctor", MethodAttributes.Public | MethodAttributes.SpecialName | MethodAttributes.RTSpecialName, typeSystem.Void);
                ctor.DeclaringType = type;

                var body = new MethodBody(ctor);
                body.InitLocals = true;
                ctor.Body = body;

                // Prepare code
                var seq = new ILSequence();
                seq.Emit(OpCodes.Nop);
                seq.Emit(OpCodes.Ret);

                // Append ret sequence
                seq.AppendTo(body);

                // Update offsets
                body.ComputeOffsets();

                // Add ctor
                type.Methods.Add(ctor);
                ctor.SetReachable(reachableContext);
            }
開發者ID:Xtremrules,項目名稱:dot42,代碼行數:28,代碼來源:StructDefaultCtorsAndDefaultField.cs

示例4: CheckMethod

		public RuleResult CheckMethod (MethodDefinition method)
		{
			// rule only applies to visible methods with parameters
			// we also exclude all p/invokes since we have a rule for them not to be visible
			if (method.IsPInvokeImpl || !method.HasParameters || !method.IsVisible ())
				return RuleResult.DoesNotApply;

			foreach (ParameterDefinition parameter in method.Parameters) {
				string how = null;
				if (parameter.IsOut) {
					// out is permitted for the "bool Try* (...)" pattern
					if ((method.ReturnType.FullName == "System.Boolean") && 
						method.Name.StartsWith ("Try", StringComparison.Ordinal)) {
						continue;
					}

					how = "out";
				} else if (parameter.IsRef ()) {
					how = "ref";
				}

				if (how != null) {
					// goal is to keep the API as simple as possible so this is more severe for public than protected methods
					Severity severity = method.IsPublic ? Severity.Medium : Severity.Low;
					string msg = String.Format ("Parameter '{0}' passed by reference ({1}).", parameter.Name, how);
					Runner.Report (parameter, severity, Confidence.Total, msg);
				}
			}

			return Runner.CurrentRuleResult;
		}
開發者ID:nolanlum,項目名稱:mono-tools,代碼行數:31,代碼來源:AvoidRefAndOutParametersRule.cs

示例5: CreateMethodBody

		HashSet<ILVariable> localVariablesToDefine = new HashSet<ILVariable>(); // local variables that are missing a definition
		
		/// <summary>
		/// Creates the body for the method definition.
		/// </summary>
		/// <param name="methodDef">Method definition to decompile.</param>
		/// <param name="context">Decompilation context.</param>
		/// <param name="parameters">Parameter declarations of the method being decompiled.
		/// These are used to update the parameter names when the decompiler generates names for the parameters.</param>
		/// <param name="localVariables">Local variables storage that will be filled/updated with the local variables.</param>
		/// <returns>Block for the method body</returns>
		public static BlockStatement CreateMethodBody(MethodDefinition methodDef,
		                                              DecompilerContext context,
		                                              IEnumerable<ParameterDeclaration> parameters = null,
		                                              ConcurrentDictionary<int, IEnumerable<ILVariable>> localVariables = null)
		{
			if (localVariables == null)
				localVariables = new ConcurrentDictionary<int, IEnumerable<ILVariable>>();
			
			MethodDefinition oldCurrentMethod = context.CurrentMethod;
			Debug.Assert(oldCurrentMethod == null || oldCurrentMethod == methodDef);
			context.CurrentMethod = methodDef;
			try {
				AstMethodBodyBuilder builder = new AstMethodBodyBuilder();
				builder.methodDef = methodDef;
				builder.context = context;
				builder.typeSystem = methodDef.Module.TypeSystem;
				if (Debugger.IsAttached) {
					return builder.CreateMethodBody(parameters, localVariables);
				} else {
					try {
						return builder.CreateMethodBody(parameters, localVariables);
					} catch (OperationCanceledException) {
						throw;
					} catch (Exception ex) {
						throw new ICSharpCode.Decompiler.DecompilerException(methodDef, ex);
					}
				}
			} finally {
				context.CurrentMethod = oldCurrentMethod;
			}
		}
開發者ID:JustasB,項目名稱:cudafy,代碼行數:42,代碼來源:AstMethodBodyBuilder.cs

示例6: AddDefaultConstructor

        /// <summary>
        /// Adds a default constructor to the target type.
        /// </summary>
        /// <param name="parentType">The base class that contains the default constructor that will be used for constructor chaining..</param>
        /// <param name="targetType">The type that will contain the default constructor.</param>
        /// <returns>The default constructor.</returns>
        public static MethodDefinition AddDefaultConstructor(this TypeDefinition targetType, Type parentType)
        {
            var module = targetType.Module;
            var voidType = module.Import(typeof(void));
            var methodAttributes = MethodAttributes.Public | MethodAttributes.HideBySig
                                   | MethodAttributes.SpecialName | MethodAttributes.RTSpecialName;

            var flags = BindingFlags.Public | BindingFlags.NonPublic | BindingFlags.Instance;
            var objectConstructor = parentType.GetConstructor(flags, null, new Type[0], null);

            // Revert to the System.Object constructor
            // if the parent type does not have a default constructor
            if (objectConstructor == null)
                objectConstructor = typeof(object).GetConstructor(new Type[0]);

            var baseConstructor = module.Import(objectConstructor);

            // Define the default constructor
            var ctor = new MethodDefinition(".ctor", methodAttributes, voidType)
                           {
                               CallingConvention = MethodCallingConvention.StdCall,
                               ImplAttributes = (MethodImplAttributes.IL | MethodImplAttributes.Managed)
                           };

            var IL = ctor.Body.CilWorker;

            // Call the constructor for System.Object, and exit
            IL.Emit(OpCodes.Ldarg_0);
            IL.Emit(OpCodes.Call, baseConstructor);
            IL.Emit(OpCodes.Ret);

            targetType.Constructors.Add(ctor);

            return ctor;
        }
開發者ID:slieser,項目名稱:LinFu,代碼行數:41,代碼來源:TypeDefinitionExtensions.cs

示例7: ILBlockTranslator

        public ILBlockTranslator(AssemblyTranslator translator, DecompilerContext context, MethodReference methodReference, MethodDefinition methodDefinition, ILBlock ilb, IEnumerable<ILVariable> parameters, IEnumerable<ILVariable> allVariables)
        {
            Translator = translator;
            Context = context;
            ThisMethodReference = methodReference;
            ThisMethod = methodDefinition;
            Block = ilb;

            SpecialIdentifiers = new JSIL.SpecialIdentifiers(TypeSystem);

            if (methodReference.HasThis)
                Variables.Add("this", JSThisParameter.New(methodReference.DeclaringType, methodReference));

            foreach (var parameter in parameters) {
                if ((parameter.Name == "this") && (parameter.OriginalParameter.Index == -1))
                    continue;

                ParameterNames.Add(parameter.Name);
                Variables.Add(parameter.Name, new JSParameter(parameter.Name, parameter.Type, methodReference));
            }

            foreach (var variable in allVariables) {
                var v = JSVariable.New(variable, methodReference);
                if (Variables.ContainsKey(v.Identifier)) {
                    v = new JSVariable(variable.OriginalVariable.Name, variable.Type, methodReference);
                    RenamedVariables[variable] = v;
                    Variables.Add(v.Identifier, v);
                } else {
                    Variables.Add(v.Identifier, v);
                }
            }
        }
開發者ID:aprishchepov,項目名稱:JSIL,代碼行數:32,代碼來源:ILBlockTranslator.cs

示例8: AddStaticPrototypeCall

        private static void AddStaticPrototypeCall(MethodDefinition method, FieldDefinition delegateField, FieldDefinition prototypeField)
        {
            Debug.Assert(prototypeField.IsStatic);
            var firstOpcode = method.Body.Instructions.First();
            var il = method.Body.GetILProcessor();

            TypeDefinition delegateType = delegateField.FieldType.Resolve();
            var invokeMethod = delegateType.Methods.Single(m => m.Name == "Invoke");
            int allParamsCount = method.Parameters.Count + (method.IsStatic ? 0 : 1); //all params and maybe this

            var instructions = new[]
            {
                il.Create(OpCodes.Ldsflda, prototypeField),
                il.Create(OpCodes.Ldfld, delegateField),
                il.Create(OpCodes.Brfalse, firstOpcode),

                il.Create(OpCodes.Ldsflda, prototypeField),
                il.Create(OpCodes.Ldfld, delegateField),
            }.Concat(
                Enumerable.Range(0, allParamsCount).Select(i => il.Create(OpCodes.Ldarg, i))
            ).Concat(new[]
            {
                il.Create(OpCodes.Callvirt, invokeMethod),
                il.Create(OpCodes.Ret),
            });

            foreach (var instruction in instructions)
                il.InsertBefore(firstOpcode, instruction);
        }
開發者ID:Djuffin,項目名稱:Mice,代碼行數:29,代碼來源:Program.cs

示例9: CopyMethod

        /// <summary>
        /// 
        /// </summary>
        /// <param name="yourMethod"></param>
        /// <param name="targetName"></param>
        /// <returns></returns>
        private MethodDefinition CopyMethod(MethodDefinition yourMethod, string targetName)
        {
            var targetMethod = new MethodDefinition(targetName, yourMethod.Attributes,
                yourMethod.ReturnType) {
                    ImplAttributes = yourMethod.ImplAttributes,
                    SemanticsAttributes = yourMethod.SemanticsAttributes,
                    CallingConvention = yourMethod.CallingConvention,
                    //all the Attributes and Conventions take care of most of the IsX/HasY properties, except for a few.
                    //this can be seen by looking at the Cecil code, where you can see which fields MethodDefinition has.
                    HasThis = yourMethod.HasThis,
                    ExplicitThis = yourMethod.ExplicitThis,
                    NoInlining = yourMethod.NoInlining,
                    NoOptimization = yourMethod.NoOptimization,
                    ReturnType = yourMethod.ReturnType //<---- this is temporary (setting it again to emphasize)
                };

            targetMethod.SecurityDeclarations.AddRange(yourMethod.SecurityDeclarations.Select(x => new SecurityDeclaration(x.Action, x.GetBlob())));

            foreach (var yourTypeParam in yourMethod.GenericParameters) {
                var targetTypeParam = new GenericParameter(yourTypeParam.Name, targetMethod) {
                    Attributes = yourTypeParam.Attributes //includes non-type constraints
                };
                targetMethod.GenericParameters.Add(targetTypeParam);
            }

            //we do this so we can perform collision detection later on.
            foreach (var yourParam in yourMethod.Parameters) {
                targetMethod.Parameters.Add(new ParameterDefinition(yourParam.ParameterType));
            }

            return targetMethod;
        }
開發者ID:GregRos,項目名稱:Patchwork,代碼行數:38,代碼來源:CreateNew.cs

示例10: MethodMatch

        public static bool MethodMatch(MethodDefinition candidate, MethodDefinition method)
        {
            if (!candidate.IsVirtual)
            {
                return false;
            }

            if (candidate.Name != method.Name)
            {
                return false;
            }

            if (!Helpers.TypeMatch(candidate.ReturnType, method.ReturnType))
            {
                return false;
            }

            if (candidate.Parameters.Count != method.Parameters.Count)
            {
                return false;
            }

            for (int i = 0; i < candidate.Parameters.Count; i++)
            {
                if (!Helpers.TypeMatch(candidate.Parameters[i].ParameterType, method.Parameters[i].ParameterType))
                {
                    return false;
                }
            }

            return true;
        }
開發者ID:TinkerWorX,項目名稱:Bridge,代碼行數:32,代碼來源:Helpers.Cecil.cs

示例11: GetWeaver

 public override IWeaver GetWeaver(MethodDefinition method, FieldDefinition mixin)
 {
     if (method.CustomAttributes.Any (a => a.AttributeType.FullName == Constants.AsyncStateMachineAttribute))
         return GetAsyncMethodWeaver (method, mixin);
     return new FakeWeaver ();
     throw new NotImplementedException ();
 }
開發者ID:JeanSebTr,項目名稱:Comedian,代碼行數:7,代碼來源:ActorEngine.cs

示例12: CheckMethod

		public RuleResult CheckMethod (MethodDefinition method)
		{
			if (!method.HasBody)
				return RuleResult.DoesNotApply;

			// check if the method contains a Isinst, Ldnull *and* Ceq instruction
			if (!bitmask.IsSubsetOf (OpCodeEngine.GetBitmask (method)))
				return RuleResult.DoesNotApply;

			IList<Instruction> instructions = method.Body.Instructions;
			int n = instructions.Count - 2;
			for (int i = 0; i < n; i++) {
				Code code0 = instructions [i].OpCode.Code;
				if (code0 != Code.Isinst)
					continue;
				Code code1 = instructions [i + 1].OpCode.Code;
				if (code1 != Code.Ldnull)
					continue;
				Code code2 = instructions [i + 2].OpCode.Code;
				if (code2 != Code.Ceq)
					continue;

				Runner.Report (method, instructions[i], Severity.High, Confidence.High);
			}

			return Runner.CurrentRuleResult;
		}
開發者ID:FreeBSD-DotNet,項目名稱:mono-tools,代碼行數:27,代碼來源:UseIsOperatorRule.cs

示例13: Build

        public List<ILNode> Build(MethodDefinition methodDef)
        {
            this.methodDef = methodDef;

            // Make editable copy
            List<Instruction> body = new List<Instruction>(methodDef.Body.Instructions);

            if (body.Count == 0) return new List<ILNode>();

            StackAnalysis(body, methodDef);

            // Create branch labels for instructins; use the labels as branch operands
            foreach (Instruction inst in body) {
                if (inst.Operand is Instruction[]) {
                    foreach(Instruction target in (Instruction[])inst.Operand) {
                        if (!labels.ContainsKey(target)) {
                            labels[target] = new ILLabel() { Name = "IL_" + target.Offset.ToString("X2") };
                        }
                    }
                } else if (inst.Operand is Instruction) {
                    Instruction target = (Instruction)inst.Operand;
                    if (!labels.ContainsKey(target)) {
                        labels[target] = new ILLabel() { Name = "IL_" + target.Offset.ToString("X2") };
                    }
                }
            }

            List<ILNode> ast = ConvertToAst(body, methodDef.Body.ExceptionHandlers);

            return ast;
        }
開發者ID:almazik,項目名稱:ILSpy,代碼行數:31,代碼來源:ILAstBuilder.cs

示例14: createMethod

 public MethodDefinition createMethod(String sMethodName, MethodAttributes maMethodAttributes,
                                      TypeReference trReturnType)
 {
     var newMethod = new MethodDefinition(sMethodName, maMethodAttributes, trReturnType);
     newMethod.Body.CilWorker.Emit(OpCodes.Ret);
     return newMethod;
 }
開發者ID:o2platform,項目名稱:O2.Platform.Projects.Misc_and_Legacy,代碼行數:7,代碼來源:CecilAssemblyBuilder.cs

示例15: CopyMethodData

        private static void CopyMethodData(MethodDefinition templateMethod, MethodDefinition newMethod)
        {
            foreach (var parameterDefinition in templateMethod.Parameters)
            {
                newMethod.Parameters.Add(parameterDefinition);
            }

            if (templateMethod.HasBody)
            {
                newMethod.Body.InitLocals = true;

                foreach (var variableDefinition in templateMethod.Body.Variables)
                {
                    newMethod.Body.Variables.Add(variableDefinition);
                }

                foreach (ExceptionHandler exceptionHandler in templateMethod.Body.ExceptionHandlers)
                {
                    newMethod.Body.ExceptionHandlers.Add(exceptionHandler);
                }

                foreach (var instruction in templateMethod.Body.Instructions)
                {
                    newMethod.Body.Instructions.Add(instruction);
                }

                newMethod.Body.OptimizeMacros();
            }
        }
開發者ID:OmerRaviv,項目名稱:StaticProxy.Fody,代碼行數:29,代碼來源:MethodDefinitionExtensions.cs


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