Je fais une petite modification de votre requête lambda.
Lorsque le type de paramètre si vous générique doit faire ce genre:
ajouter pi.ParameterType.GetGenericTypeDefinition()
et
(m.ReturnType.IsGenericType ? m.ReturnType.GetGenericTypeDefinition() : m.ReturnType) == returnType)
De cette façon, la méthode de travail très fin
MethodInfo foo1 = (from m in t.GetMethods(BindingFlags.Public | BindingFlags.Static)
where m.Name == name
&& m.GetGenericArguments().Length == genericArgTypes.Length
&& m.GetParameters().Select(pi => pi.ParameterType.IsGenericType ? pi.ParameterType.GetGenericTypeDefinition() : pi.ParameterType).SequenceEqual(argTypes) &&
(returnType==null || (m.ReturnType.IsGenericType ? m.ReturnType.GetGenericTypeDefinition() : m.ReturnType) == returnType)
select m).FirstOrDefault();
if (foo1 != null)
{
return foo1.MakeGenericMethod(genericArgTypes);
}
return null;
Exemple:
Avec la modification de la méthode que je peux appeler cette méthode l'extension
public static IQueryable<T> FilterCulture<T>(this Table<T> t, IDatabaseFilter filter)
Avec mon nouvel assistant comme celui-ci
var QueryableExpression = MethodInfoHelper.GetGenericMethod(typeof(LinqFilterExtension), "FilterCulture", new Type[] { rowType }, new Type[] { typeof(Table<>), typeof(IDatabaseFilter) }, typeof(IQueryable<>));
La signature de mon aide est
public static MethodInfo GetGenericMethod(Type t, string name, Type[] genericArgTypes, Type[] argTypes, Type returnType)
Il vous manque un type de retour dans vos définitions de méthode. – Ray
en effet, pas plus, merci. –