| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- //
- // System.ComponentModel.PropertyDescriptor.cs
- //
- // Author:
- // Miguel de Icaza ([email protected])
- //
- // (C) Ximian, Inc. http://www.ximian.com
- //
- using System;
- using System.Collections;
- namespace System.ComponentModel {
- public abstract class PropertyDescriptor : MemberDescriptor {
- protected PropertyDescriptor (MemberDescriptor reference)
- : base (reference)
- {
- }
- protected PropertyDescriptor (MemberDescriptor reference, Attribute [] attrs)
- : base (reference, attrs)
- {
- }
- protected PropertyDescriptor (string name, Attribute [] attrs)
- : base (name, attrs)
- {
- }
- public abstract Type ComponentType { get; }
- public virtual TypeConverter Converter {
- get {
- return TypeDescriptor.GetConverter (PropertyType);
- }
- }
- public virtual bool IsLocalizable {
- get {
- foreach (Attribute attr in AttributeArray){
- if (attr is LocalizableAttribute){
- return ((LocalizableAttribute) attr).IsLocalizable;
- }
- }
- return false;
- }
- }
- public abstract bool IsReadOnly { get; }
- public abstract Type PropertyType { get; }
- public DesignerSerializationVisibility SerializationVisibility {
- get {
- foreach (Attribute attr in AttributeArray){
- if (attr is DesignerSerializationVisibilityAttribute){
- DesignerSerializationVisibilityAttribute a;
- a = (DesignerSerializationVisibilityAttribute) attr;
- return a.Visibility;
- }
- }
- //
- // Is this a good default if we cant find the property?
- //
- return DesignerSerializationVisibility.Hidden;
- }
- }
- Hashtable notifiers;
- public virtual void AddValueChanged (object component, EventHandler handler)
- {
- EventHandler component_notifiers;
-
- if (component == null)
- throw new ArgumentNullException ("component");
- if (handler == null)
- throw new ArgumentNullException ("handler");
- if (notifiers == null)
- notifiers = new Hashtable ();
- component_notifiers = (EventHandler) notifiers [component];
- if (component_notifiers != null)
- component_notifiers += handler;
- else
- notifiers [component] = handler;
- }
-
- protected virtual void OnValueChanged (object component, EventArgs e)
- {
- if (notifiers == null)
- return;
- EventHandler component_notifiers = (EventHandler) notifiers [component];
- if (component_notifiers == null)
- return;
- component_notifiers (component, e);
- }
- public abstract object GetValue (object component);
- }
- }
|