[Mono-bugs] [Bug 52587][Wis] New - We thow an exception when a method hides a field
bugzilla-daemon@bugzilla.ximian.com
bugzilla-daemon@bugzilla.ximian.com
Sun, 4 Jan 2004 15:20:28 -0500 (EST)
Please do not reply to this email- if you want to comment on the bug, go to the
URL shown below and enter your comments there.
Changed by bmaurer@users.sf.net.
http://bugzilla.ximian.com/show_bug.cgi?id=52587
--- shadow/52587 2004-01-04 15:20:28.000000000 -0500
+++ shadow/52587.tmp.30001 2004-01-04 15:20:28.000000000 -0500
@@ -0,0 +1,86 @@
+Bug#: 52587
+Product: Mono/Compilers
+Version: unspecified
+OS:
+OS Details:
+Status: NEW
+Resolution:
+Severity:
+Priority: Wishlist
+Component: C#
+AssignedTo: mono-bugs@ximian.com
+ReportedBy: bmaurer@users.sf.net
+QAContact: mono-bugs@ximian.com
+TargetMilestone: ---
+URL:
+Cc:
+Summary: We thow an exception when a method hides a field
+
+using System;
+
+class A {
+ public int foo = 1;
+}
+
+class B : A {
+ public new int foo ()
+ {
+ return 1;
+ }
+
+ static void Main ()
+ {
+ B b = new B ();
+ Console.WriteLine (b.foo ());
+ }
+}
+
+
+We throw:
+System.ArrayTypeMismatchException: (Types:
+source=System.Reflection.MemberInfo; target=System.Reflection.MethodBase)
+ in (at /devel/mcs/class/corlib/System/Array.cs:682) Array.Copy
+(System.Array, int, System.Array, int, int)
+ in (at /devel/mcs/class/corlib/System/Array.cs:1010) Array.CopyTo
+(System.Array, int)
+ in (at /devel/mcs/mcs/ecore.cs:2338) MethodGroupExpr..ctor
+(System.Reflection.MemberInfo[], Mono.CSharp.Location)
+ in (at /devel/mcs/mcs/ecore.cs:548) Expression.MemberLookup
+(Mono.CSharp.EmitContext, System.Type, System.Type, System.Type, string,
+System.Reflection.MemberTypes, System.Reflection.BindingFlags,
+Mono.CSharp.Location)
+ in (at /devel/mcs/mcs/ecore.cs:613) Expression.MemberLookupFinal
+(Mono.CSharp.EmitContext, System.Type, System.Type, string,
+System.Reflection.MemberTypes, System.Reflection.BindingFlags,
+Mono.CSharp.Location)
+ in (at /devel/mcs/mcs/ecore.cs:599) Expression.MemberLookupFinal
+(Mono.CSharp.EmitContext, System.Type, System.Type, string,
+Mono.CSharp.Location)
+ in (at /devel/mcs/mcs/expression.cs:6989) MemberAccess.DoResolve
+(Mono.CSharp.EmitContext, Mono.CSharp.Expression, Mono.CSharp.ResolveFlags)
+ in (at /devel/mcs/mcs/expression.cs:7021) MemberAccess.DoResolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/ecore.cs:282) Expression.Resolve
+(Mono.CSharp.EmitContext, Mono.CSharp.ResolveFlags)
+ in (at /devel/mcs/mcs/expression.cs:4983) Invocation.DoResolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/ecore.cs:282) Expression.Resolve
+(Mono.CSharp.EmitContext, Mono.CSharp.ResolveFlags)
+ in (at /devel/mcs/mcs/ecore.cs:359) Expression.Resolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/expression.cs:3919) Argument.Resolve
+(Mono.CSharp.EmitContext, Mono.CSharp.Location)
+ in (at /devel/mcs/mcs/expression.cs:5008) Invocation.DoResolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/ecore.cs:282) Expression.Resolve
+(Mono.CSharp.EmitContext, Mono.CSharp.ResolveFlags)
+ in (at /devel/mcs/mcs/ecore.cs:359) Expression.Resolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/ecore.cs:1288)
+ExpressionStatement.ResolveStatement (Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/statement.cs:490) StatementExpression.Resolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/statement.cs:1677) Block.Resolve
+(Mono.CSharp.EmitContext)
+ in (at /devel/mcs/mcs/codegen.cs:455) EmitContext.EmitTopBlock
+(Mono.CSharp.Block, Mono.CSharp.InternalParameters, Mono.CSharp.Location)