//
// Delegate container implementation
//
- public class Delegate : TypeContainer
+ public class Delegate : TypeContainer, IParametersMember
{
FullNamedExpression ReturnType;
- public readonly ParametersCompiled Parameters;
+ readonly ParametersCompiled parameters;
Constructor Constructor;
Method InvokeBuilder;
ModFlags = ModifiersExtensions.Check (AllowedModifiers, mod_flags,
IsTopLevel ? Modifiers.INTERNAL :
Modifiers.PRIVATE, name.Location, Report);
- Parameters = param_list;
+ parameters = param_list;
spec = new TypeSpec (Kind, null, this, null, ModFlags | Modifiers.SEALED);
}
+ #region Properties
+ public TypeSpec MemberType {
+ get {
+ return ReturnType.Type;
+ }
+ }
+
+ public AParametersCollection Parameters {
+ get {
+ return parameters;
+ }
+ }
+ #endregion
+
public override void ApplyAttributeBuilder (Attribute a, MethodSpec ctor, byte[] cdata, PredefinedAttributes pa)
{
if (a.Target == AttributeTargets.ReturnValue) {
// First, call the `out of band' special method for
// defining recursively any types we need:
//
- var p = Parameters;
+ var p = parameters;
if (!p.Resolve (this))
return false;
int param = 0;
for (int i = 0; i < Parameters.FixedParameters.Length; ++i) {
- Parameter p = Parameters [i];
+ Parameter p = parameters [i];
if ((p.ModFlags & Parameter.Modifier.ISBYREF) == 0)
continue;
public override void DefineConstants ()
{
if (!Parameters.IsEmpty) {
- Parameters.ResolveDefaultValues (this);
+ parameters.ResolveDefaultValues (this);
}
}
}
}
- Parameters.ApplyAttributes (this, InvokeBuilder.MethodBuilder);
+ parameters.ApplyAttributes (this, InvokeBuilder.MethodBuilder);
Constructor.ConstructorBuilder.SetImplementationFlags (MethodImplAttributes.Runtime);
InvokeBuilder.MethodBuilder.SetImplementationFlags (MethodImplAttributes.Runtime);
return false;
}
- Parameters.VerifyClsCompliance (this);
+ parameters.VerifyClsCompliance (this);
if (!ReturnType.Type.IsCLSCompliant ()) {
Report.Warning (3002, 1, Location, "Return type of `{0}' is not CLS-compliant",
}
//
- // Is the member of the correct type ?
- // Destructors are ignored as they cannot be overridden by user
+ // Is the member of same type ?
+ //
if ((entry.Kind & ~MemberKind.Destructor & mkind & MemberKind.MaskType) == 0) {
- if ((entry.Kind & MemberKind.Destructor) == 0 && (member_param == null || !(entry is IParametersMember))) {
+ // Destructors are ignored as they cannot be overridden by user
+ if ((entry.Kind & MemberKind.Destructor) != 0)
+ continue;
+
+ // Only different arity methods hide
+ if (mkind != MemberKind.Method && member.MemberName.Arity != entry.Arity)
+ continue;
+
+ if ((member_param == null || !(entry is IParametersMember))) {
bestCandidate = entry;
return null;
}
continue;
var pm = entry as IParametersMember;
- if (pm == null)
- continue;
+ AParametersCollection entry_parameters;
+ if (pm == null) {
+ if (entry.Kind != MemberKind.Delegate)
+ continue;
+
+ // TODO: I don't have DelegateSpec
+ entry_parameters = Delegate.GetParameters (member.Compiler, (TypeSpec) entry);
+ } else {
+ entry_parameters = pm.Parameters;
+ }
if (entry.IsAccessor != member is AbstractPropertyEventMethod)
continue;
- if (!TypeSpecComparer.Override.IsEqual (pm.Parameters, member_param))
+ if (!TypeSpecComparer.Override.IsEqual (entry_parameters, member_param))
continue;
}