Merge pull request #1185 from esdrubal/http-reuse
[mono.git] / mcs / mcs / field.cs
index fa3b07334da6f9a6e2d458de502e49e0df54ed8d..3531af044f3bc39543000501a647a96f409e8b7a 100644 (file)
@@ -223,7 +223,9 @@ namespace Mono.CSharp
                        if (MemberType.IsStatic)
                                Error_VariableOfStaticClass (Location, GetSignatureForError (), MemberType, Report);
 
-                       CheckBase ();
+                       if (!IsCompilerGenerated)
+                               CheckBase ();
+
                        IsTypePermitted ();
                }
 
@@ -603,9 +605,23 @@ namespace Mono.CSharp
                        if (TypeSpec.IsReferenceType (MemberType))
                                return true;
 
-                       if (MemberType.IsEnum)
+                       if (MemberType.IsPointer)
                                return true;
 
+                       if (MemberType.IsEnum) {
+                               switch (EnumSpec.GetUnderlyingType (MemberType).BuiltinType) {
+                               case BuiltinTypeSpec.Type.SByte:
+                               case BuiltinTypeSpec.Type.Byte:
+                               case BuiltinTypeSpec.Type.Short:
+                               case BuiltinTypeSpec.Type.UShort:
+                               case BuiltinTypeSpec.Type.Int:
+                               case BuiltinTypeSpec.Type.UInt:
+                                       return true;
+                               default:
+                                       return false;
+                               }
+                       }
+
                        return false;
                }
 
@@ -689,4 +705,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;
+               }
+       }
 }