diff --git a/src/AddIns/DisplayBindings/FormsDesigner/Project/Src/DesignerGenerator/AbstractDesignerGenerator.cs b/src/AddIns/DisplayBindings/FormsDesigner/Project/Src/DesignerGenerator/AbstractDesignerGenerator.cs index cda90f1c2e..9a9c4214f8 100644 --- a/src/AddIns/DisplayBindings/FormsDesigner/Project/Src/DesignerGenerator/AbstractDesignerGenerator.cs +++ b/src/AddIns/DisplayBindings/FormsDesigner/Project/Src/DesignerGenerator/AbstractDesignerGenerator.cs @@ -344,8 +344,11 @@ namespace ICSharpCode.FormsDesigner continue; if (expr.TargetType.BaseType != "System.ComponentModel.ISupportInitialize") continue; - CodeMemberField field = formClass.Members.OfType().First(f => this.formClass.ProjectContent.Language.NameComparer.Equals(fieldRef.FieldName, f.Name)); - IClass fieldType = this.formClass.ProjectContent.GetClass(field.Type.BaseType, 0); + IField field = this.formClass.DefaultReturnType.GetFields() + .First(f => this.formClass.ProjectContent.Language.NameComparer.Equals(fieldRef.FieldName, f.Name)); + if (field.ReturnType == null) + continue; + IClass fieldType = field.ReturnType.GetUnderlyingClass(); if (fieldType == null) continue; if (!fieldType.IsTypeInInheritanceTree(iSupportInitializeInterface))