Merge pull request #1230 from esdrubal/xslattribute
[mono.git] / mcs / mcs / field.cs
index fa3b07334da6f9a6e2d458de502e49e0df54ed8d..e3555b9383e387f42964b063ba1e7ab232b862ee 100644 (file)
@@ -223,7 +223,9 @@ namespace Mono.CSharp
                        if (MemberType.IsStatic)
                                Error_VariableOfStaticClass (Location, GetSignatureForError (), MemberType, Report);
 
-                       CheckBase ();
+                       if (!IsCompilerGenerated)
+                               CheckBase ();
+
                        IsTypePermitted ();
                }
 
@@ -689,4 +691,39 @@ namespace Mono.CSharp
                        return true;
                }
        }
+
+       class PrimaryConstructorField : Field
+       {
+               //
+               // Proxy resolved parameter type expression to avoid type double resolve
+               // and problems with correct resolve context on partial classes
+               //
+               sealed class TypeExpressionFromParameter : TypeExpr
+               {
+                       Parameter parameter;
+
+                       public TypeExpressionFromParameter (Parameter parameter)
+                       {
+                               this.parameter = parameter;
+                               eclass = ExprClass.Type;
+                               loc = parameter.Location;
+                       }
+
+                       public override TypeSpec ResolveAsType (IMemberContext mc, bool allowUnboundTypeArguments)
+                       {
+                               return parameter.Type;
+                       }
+               }
+
+               public PrimaryConstructorField (TypeDefinition parent, Parameter parameter)
+                       : base (parent, new TypeExpressionFromParameter (parameter), Modifiers.PRIVATE, new MemberName (parameter.Name, parameter.Location), null)
+               {
+                       caching_flags |= Flags.IsUsed | Flags.IsAssigned;
+               }
+
+               public override string GetSignatureForError ()
+               {
+                       return MemberName.Name;
+               }
+       }
 }