// // System.ComponentModel.Component.cs // // Author: // Miguel de Icaza (miguel@ximian.com) // // (C) Ximian, Inc. http://www.ximian.com // using System; namespace System.ComponentModel { // // Component class. // // // // Longer description // public class Component : MarshalByRefObject, IComponent, IDisposable { EventHandlerList event_handlers; ISite mySite; object disposedEvent = new object (); // // Component Constructor // public Component () { event_handlers = null; } // // Get IContainer of this Component // public IContainer Container { get { return mySite.Container; } } protected bool DesignMode { get { return mySite.DesignMode; } } protected EventHandlerList Events { get { // Note: space vs. time tradeoff // We create the object here if it's never be accessed before. This potentially // saves space. However, we must check each time the propery is accessed to // determine whether we need to create the object, which increases overhead. // We could put the creation in the contructor, but that would waste space // if it were never used. However, accessing this property would be faster. if (null == event_handlers) { event_handlers = new EventHandlerList(); } return event_handlers; } } public virtual ISite Site { get { return mySite; } set { mySite = value; } } ~Component() { Dispose (false); } // // Dispose resources used by this component // public void Dispose () { Dispose (true); GC.SuppressFinalize (this); } // // Controls disposal of resources used by this. // // // Controls which resources are released // // // if release_all is set to true, both managed and unmanaged // resources should be released. If release_all is set to false, // only unmanaged resources should be disposed // protected virtual void Dispose (bool release_all) { if (release_all) { EventHandler eh = (EventHandler) Events [disposedEvent]; if (eh != null) eh (this, EventArgs.Empty); } mySite = null; } // // Implements the IServiceProvider interface // [MonoTODO] protected virtual object GetService (Type service) { // FIXME: Not sure what this should do. return null; } public override string ToString () { if (mySite == null) return GetType ().ToString (); return String.Format ("{0} [{1}]", mySite.Name, GetType ().ToString ()); } // // This event is called when the component is explicitly disposed. // public event EventHandler Disposed { add { Events.AddHandler (disposedEvent, value); } remove { Events.RemoveHandler (disposedEvent, value); } } } }