# HG changeset patch # User cin # Date 1408888662 -14400 # Node ID f757da6161a14f2c6dc096e3822b5ecc58500202 # Parent 1ef98bd704242d932764d0ab93d9347f6a8eae0e !bug 100 + 2h fixed gregression diff -r 1ef98bd70424 -r f757da6161a1 Source/Data/Linq/Query.cs --- a/Source/Data/Linq/Query.cs Fri Aug 22 17:34:46 2014 +0400 +++ b/Source/Data/Linq/Query.cs Sun Aug 24 17:57:42 2014 +0400 @@ -148,7 +148,7 @@ { query = new ExpressionBuilder(new Query(), dataContextInfo, expr, null).Build(); } - catch (Exception) + catch (Exception err) { if (!Configuration.Linq.GenerateExpressionTest) { diff -r 1ef98bd70424 -r f757da6161a1 Source/Data/Linq/ReflectionHelper.cs --- a/Source/Data/Linq/ReflectionHelper.cs Fri Aug 22 17:34:46 2014 +0400 +++ b/Source/Data/Linq/ReflectionHelper.cs Sun Aug 24 17:57:42 2014 +0400 @@ -42,12 +42,7 @@ // return ((PropertyInfo)((MemberExpression)ex).Member).GetGetMethod(); /// HACK - var mce = (MethodCallExpression)ex; - var mi = mce.Method; - if (mi.IsVirtual && mi.DeclaringType != mce.Object.Type) - mi = mce.Object.Type.GetMethod(mi.Name, mi.GetParameters().Select(p => p.ParameterType).ToArray()); - - return mi; + return ExtractMethodInfo ((MethodCallExpression)ex); } } @@ -66,7 +61,7 @@ public static MethodInfo ExtractMethodInfo(MethodCallExpression mce) { var mi = mce.Method; - if (mi.IsVirtual && mi.DeclaringType != mce.Object.Type) + if (mi.IsVirtual && mi.DeclaringType != mce.Object.Type && !mce.Object.Type.IsInterface) mi = mce.Object.Type.GetMethod(mi.Name, mi.GetParameters().Select(p => p.ParameterType).ToArray()); return mi;