Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 3275416
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 17, 20262026-05-17T19:08:31+00:00 2026-05-17T19:08:31+00:00

I have a method that given a delegate Type argument (not a generic), it

  • 0

I have a method that given a delegate Type argument (not a generic), it returns a Delegate that it created that implements the signature. It internally creates a dynamic method using Expression trees. The delegate type must be of this form Func<SomeParam,IamDerivedObject>,a func where IamDerivedObject is an inheritor of IamDerivedObject. The method uses the type information to figure out which object to instance, so simply using the interface for creation would be disastrous. The calling is done from a static method that returns IamDerivedObject.

In .NET 4 code, I can do this::
var myDelegate = MakeMethod(typeArgument) as Func<SomeParam,IamDerivedObject>

In .Net 3.5 this does not work. And I’m stuck with having to know the type to call the invoke method, or using another expression generated delegate to invoke it and cache that delegate. This means more runtime generated code.
Unfortunately, I cannot use the .NET 4 code as the assembly for the time being must be .NET 3.5 code as it relies on a third party dll which does not work in 4.0.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-17T19:08:31+00:00Added an answer on May 17, 2026 at 7:08 pm

    I figured out an approach, but it basically requires some reflection magic to figure it out.

        /// <summary>
        /// Converts the delegate to <see cref="TDelegate"/>, provided the types are compatible. Can use
        /// variance of delegate typing in .NET 4 for a speedy conversion. Otherwise, uses Delegate.CreateDelegate
        /// to create a new delegate with the appropriate signature. 
        /// </summary>
        /// <typeparam name="TDelegate">The target delegate type.</typeparam>
        /// <param name="delegate">The @delegate.</param>
        /// <returns></returns>
        public static TDelegate ConvertDelegate<TDelegate>(Delegate @delegate) where TDelegate : class
        {
            ArgumentValidator.AssertIsNotNull(() => @delegate);
            var targetType = typeof(TDelegate);
            ArgumentValidator.AssertIsDelegateType(() => targetType);
            var currentType = @delegate.GetType();
            if (targetType.IsAssignableFrom(currentType))
            {
                return @delegate as TDelegate; // let's skip as much of this as we can.
            }
    
            var currentMethod = currentType.GetMethod("Invoke");
            var targetMethod = targetType.GetMethod("Invoke");
            if (!AreDelegateInvokeMethodsCompatible(currentMethod, targetMethod, true))
            {
                throw new ArgumentException(string.Format("{0} is incompatible with {1}.", currentType, targetType), ExpressionHelper.GetMemberName(() => @delegate));
            }
            var invocationList = @delegate.GetInvocationList();
            return DelegateHelper.Combine(@delegate.GetInvocationList()
                .Select(d => IsMethodRunTimeGenerated(d.Method) ?
                            GetDynamicMethodFromMethodInfo(d.Method).CreateDelegate<TDelegate>(d.Target) :
                            DelegateHelper.CreateDelegate<TDelegate>(d.Target, d.Method)).ToArray());
        }
        #region Private Static Variables 
        private static Type s_RTDynamicMethodType = Type.GetType("System.Reflection.Emit.DynamicMethod+RTDynamicMethod",false,true);
        private static Func<MethodInfo, DynamicMethod> s_GetDynamicMethodDelegate = CreateGetDynamicMethodDelegate();
        #endregion Private Static Variables 
    
        private static Func<MethodInfo, DynamicMethod> CreateGetDynamicMethodDelegate()
        {
            var param = Expression.Parameter(
                            typeof(MethodInfo),
                            typeof(MethodInfo).Name
            );
            var expression = Expression.Lambda<Func<MethodInfo, DynamicMethod>>(
                Expression.Field(
                    Expression.Convert(
                        param,
                        s_RTDynamicMethodType
                    ),
                    s_RTDynamicMethodType.GetField("m_owner", BindingFlags.NonPublic | BindingFlags.Instance)
                ),
                param
                );
            return expression.Compile();
        }
    

    I’m not going to leave up my delegatehelper class unless somebody else can really want it. But the point is it is possible, and actually pretty quick. Conversion is usually less than 1ms, not nearly as fast as method group conversion which is near instantaneous, but you know thats something.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have method that returns module path of given class name def findModulePath(path, className):
I have a method that accepts a generic delegate as a parameter, and inserts
I have method that returns Drawable , and if its Bitmap object is recycled
I have a method that receives something and it needs to determine the type
Possible Duplicate: Run a code in given time interval I have a method that
I want to write generic method that checks if a given entity is in
I have a System.Reflection.MethodInfo and would like to have a method that creates a
I have a method connection(int n) which gives me all the cells number that
I have method that returned NSManagedObject and I don't know what kind of NSManagedObject
I have a method that uses ARC and takes an NSError pointer and I

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.