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 5999529
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 23, 20262026-05-23T00:33:56+00:00 2026-05-23T00:33:56+00:00

I have a generic class that has a method ‘Call’ on it with a

  • 0

I have a generic class that has a method ‘Call’ on it with a generic return type and a lambda expression as a parameter. This has to be generated with reflection, and since the types are unknown, I need to create the lambda expression the long way. I have a working solution listed below, but I do not like having to get the instance out of the generic class since it is private and does some logic on a retrieve.

Class:

public class Proxy<T>
{
    public TR Call<TR>(Func<T, TR> serviceInvoke)
    private T Instance
}

Reflection Usage:

var serviceInstance = proxy.GetType().GetProperty("Instance", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(proxy, null);
var serviceMethod = type.GetMethod(rule.ServiceMethodName);
var parameters = serviceMethod.GetParameters().Select(parameterInfo => PropertyChainNavigator.GetValueForPropertyChain(((string)rule.Parameters[parameterInfo.Name]).Split(new[] { '.' }), context)).ToArray();
var thisParam = Expression.Constant(serviceInstance);
var valueParams = parameters.Select(Expression.Constant).ToList();
var call = Expression.Call(thisParam, serviceMethod, valueParams);
var func = Expression.Lambda(call, Expression.Parameter(type)).Compile();
var callMethod = proxy.GetType().GetMethods().Where(x => x.Name == "Call" && x.ReturnType != typeof(void)).First().MakeGenericMethod(serviceMethod.ReturnType);
result = callMethod.Invoke(proxy, new[] { func });

Normal Usage:

var proxy = new Proxy<ITestClass>();
proxy.Call(x => x.Method);

I have tried to change the Expression.Call to not take an instance, but that only works on static methods. Does anyone know of a way for me to create the call, turn it into an lambda and have it compile without erroring

  • 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-23T00:33:57+00:00Added an answer on May 23, 2026 at 12:33 am

    If you used lambda instead of expressions, your current code would look like this:

    var serviceInstance = …; // retrieve using reflection
    proxy.Call(i => serviceInstance.CallMethod(parameters));
    

    Note that the lambda takes the parameter i, but doesn’t use it. I assume you want to call the method directly on i, i.e. something like this:

    proxy.Call(i => i.CallMethod(parameters));
    

    To do that, use the value of Expression.Parameter() as thisParam:

    var thisParam = Expression.Parameter(type, "i"); // the name is optional
    var call = Expression.Call(thisParam, serviceMethod, valueParams);
    var func = Expression.Lambda(call, thisParam).Compile();
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a generic class that has one type parameter (T). I needed to
I have a class that has a Generic type G In my class model
I have a generic class that should allow any type, primitive or otherwise. The
I have a generic class that I'm trying to implement implicit type casting for.
I have a generic Logger class that looks like this: class Logger { ...
I have a generic class public MyClass<TContext, T> where TContext : DataContext that effectively
I have a class that inherits a generic dictionary and an inteface public class
I have a generic class, but I want my type to be forced to
I have a generic class in C# with 2 constructors: public Houses(params T[] InitialiseElements)
I have a generic class in my project with derived classes. public class GenericClass<T>

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.