Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / CompMod / System / ComponentModel / Container.cs / 1 / Container.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.ComponentModel { using System; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.IO; using System.Security.Permissions; ////// [HostProtection(SharedState = true)] public class Container : IContainer { private ISite[] sites; private int siteCount; private ComponentCollection components; private ContainerFilterService filter; private bool checkedFilter; private object syncObj = new Object(); ~Container() { Dispose(false); } // Adds a component to the container. ////// Encapsulates /// zero or more components. /// ////// public virtual void Add(IComponent component) { Add(component, null); } // Adds a component to the container. ////// Adds the specified component to the ////// . The component is unnamed. /// /// public virtual void Add(IComponent component, String name) { lock (syncObj) { if (component == null) { return; } ISite site = component.Site; if (site != null && site.Container == this) { return; } if (sites == null) { sites = new ISite[4]; } else { // Validate that new components // have either a null name or a unique one. // ValidateName(component, name); if (sites.Length == siteCount) { ISite[] newSites = new ISite[siteCount * 2]; Array.Copy(sites, 0, newSites, 0, siteCount); sites = newSites; } } if (site != null) { site.Container.Remove(component); } ISite newSite = CreateSite(component, name); sites[siteCount++] = newSite; component.Site = newSite; components = null; } } // Creates a site for the component within the container. ////// Adds the specified component to the ///and assigns a name to /// it. /// /// protected virtual ISite CreateSite(IComponent component, string name) { return new Site(component, this, name); } // Disposes of the container. A call to the Dispose method indicates that // the user of the container has no further need for it. // // The implementation of Dispose must: // // (1) Remove any references the container is holding to other components. // This is typically accomplished by assigning null to any fields that // contain references to other components. // // (2) Release any system resources that are associated with the container, // such as file handles, window handles, or database connections. // // (3) Dispose of child components by calling the Dispose method of each. // // Ideally, a call to Dispose will revert a container to the state it was // in immediately after it was created. However, this is not a requirement. // Following a call to its Dispose method, a container is permitted to raise // exceptions for operations that cannot meaningfully be performed. // ///Creates a Site ///for the given /// and assigns the given name to the site. /// public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (disposing) { lock (syncObj) { while (siteCount > 0) { ISite site = sites[--siteCount]; site.Component.Site = null; site.Component.Dispose(); } sites = null; components = null; } } } ////// Disposes of the ////// . /// /// protected virtual object GetService(Type service) { return((service == typeof(IContainer)) ? this : null); } // The components in the container. ///[To be supplied.] ////// public virtual ComponentCollection Components { get { lock (syncObj) { if (components == null) { IComponent[] result = new IComponent[siteCount]; for (int i = 0; i < siteCount; i++) { result[i] = sites[i].Component; } components = new ComponentCollection(result); // At each component add, if we don't yet have a filter, look for one. // Components may add filters. if (filter == null && checkedFilter) { checkedFilter = false; } } if (!checkedFilter) { filter = GetService(typeof(ContainerFilterService)) as ContainerFilterService; checkedFilter = true; } if (filter != null) { ComponentCollection filteredComponents = filter.FilterComponents(components); Debug.Assert(filteredComponents != null, "Incorrect ContainerFilterService implementation."); if (filteredComponents != null) { components = filteredComponents; } } return components; } } } // Removes a component from the container. ////// Gets all the components in the ////// . /// /// public virtual void Remove(IComponent component) { Remove(component, false); } private void Remove(IComponent component, bool preserveSite) { lock (syncObj) { if (component == null) return; ISite site = component.Site; if (site == null || site.Container != this) return; if (!preserveSite) component.Site = null; for (int i = 0; i < siteCount; i++) { if (sites[i] == site) { siteCount--; Array.Copy(sites, i + 1, sites, i, siteCount - i); sites[siteCount] = null; components = null; break; } } } } protected void RemoveWithoutUnsiting(IComponent component) { Remove(component, true); } ////// Removes a component from the ////// . /// /// Validates that the given name is valid for a component. The default implementation /// verifies that name is either null or unique compared to the names of other /// components in the container. /// protected virtual void ValidateName(IComponent component, string name) { if (component == null) { throw new ArgumentNullException("component"); } if (name != null) { for (int i = 0; i < Math.Min(siteCount,sites.Length); i++) { ISite s = sites[ i ]; if (s != null && s.Name != null && string.Equals(s.Name, name, StringComparison.OrdinalIgnoreCase) && s.Component != component) { InheritanceAttribute inheritanceAttribute = (InheritanceAttribute)TypeDescriptor.GetAttributes(s.Component)[typeof(InheritanceAttribute)]; if(inheritanceAttribute.InheritanceLevel != InheritanceLevel.InheritedReadOnly) { throw new ArgumentException(SR.GetString(SR.DuplicateComponentName, name)); } } } } } private class Site : ISite { private IComponent component; private Container container; private String name; internal Site(IComponent component, Container container, String name) { this.component = component; this.container = container; this.name = name; } // The component sited by this component site. public IComponent Component { get { return component; } } // The container in which the component is sited. public IContainer Container { get { return container; } } public Object GetService(Type service) { return((service == typeof(ISite)) ? this : container.GetService(service)); } // Indicates whether the component is in design mode. public bool DesignMode { get { return false; } } // The name of the component. // public String Name { get { return name;} set { if (value == null || name == null || !value.Equals(name)) { // container.ValidateName(component, value); name = value; } } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.ComponentModel { using System; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.IO; using System.Security.Permissions; ////// [HostProtection(SharedState = true)] public class Container : IContainer { private ISite[] sites; private int siteCount; private ComponentCollection components; private ContainerFilterService filter; private bool checkedFilter; private object syncObj = new Object(); ~Container() { Dispose(false); } // Adds a component to the container. ////// Encapsulates /// zero or more components. /// ////// public virtual void Add(IComponent component) { Add(component, null); } // Adds a component to the container. ////// Adds the specified component to the ////// . The component is unnamed. /// /// public virtual void Add(IComponent component, String name) { lock (syncObj) { if (component == null) { return; } ISite site = component.Site; if (site != null && site.Container == this) { return; } if (sites == null) { sites = new ISite[4]; } else { // Validate that new components // have either a null name or a unique one. // ValidateName(component, name); if (sites.Length == siteCount) { ISite[] newSites = new ISite[siteCount * 2]; Array.Copy(sites, 0, newSites, 0, siteCount); sites = newSites; } } if (site != null) { site.Container.Remove(component); } ISite newSite = CreateSite(component, name); sites[siteCount++] = newSite; component.Site = newSite; components = null; } } // Creates a site for the component within the container. ////// Adds the specified component to the ///and assigns a name to /// it. /// /// protected virtual ISite CreateSite(IComponent component, string name) { return new Site(component, this, name); } // Disposes of the container. A call to the Dispose method indicates that // the user of the container has no further need for it. // // The implementation of Dispose must: // // (1) Remove any references the container is holding to other components. // This is typically accomplished by assigning null to any fields that // contain references to other components. // // (2) Release any system resources that are associated with the container, // such as file handles, window handles, or database connections. // // (3) Dispose of child components by calling the Dispose method of each. // // Ideally, a call to Dispose will revert a container to the state it was // in immediately after it was created. However, this is not a requirement. // Following a call to its Dispose method, a container is permitted to raise // exceptions for operations that cannot meaningfully be performed. // ///Creates a Site ///for the given /// and assigns the given name to the site. /// public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (disposing) { lock (syncObj) { while (siteCount > 0) { ISite site = sites[--siteCount]; site.Component.Site = null; site.Component.Dispose(); } sites = null; components = null; } } } ////// Disposes of the ////// . /// /// protected virtual object GetService(Type service) { return((service == typeof(IContainer)) ? this : null); } // The components in the container. ///[To be supplied.] ////// public virtual ComponentCollection Components { get { lock (syncObj) { if (components == null) { IComponent[] result = new IComponent[siteCount]; for (int i = 0; i < siteCount; i++) { result[i] = sites[i].Component; } components = new ComponentCollection(result); // At each component add, if we don't yet have a filter, look for one. // Components may add filters. if (filter == null && checkedFilter) { checkedFilter = false; } } if (!checkedFilter) { filter = GetService(typeof(ContainerFilterService)) as ContainerFilterService; checkedFilter = true; } if (filter != null) { ComponentCollection filteredComponents = filter.FilterComponents(components); Debug.Assert(filteredComponents != null, "Incorrect ContainerFilterService implementation."); if (filteredComponents != null) { components = filteredComponents; } } return components; } } } // Removes a component from the container. ////// Gets all the components in the ////// . /// /// public virtual void Remove(IComponent component) { Remove(component, false); } private void Remove(IComponent component, bool preserveSite) { lock (syncObj) { if (component == null) return; ISite site = component.Site; if (site == null || site.Container != this) return; if (!preserveSite) component.Site = null; for (int i = 0; i < siteCount; i++) { if (sites[i] == site) { siteCount--; Array.Copy(sites, i + 1, sites, i, siteCount - i); sites[siteCount] = null; components = null; break; } } } } protected void RemoveWithoutUnsiting(IComponent component) { Remove(component, true); } ////// Removes a component from the ////// . /// /// Validates that the given name is valid for a component. The default implementation /// verifies that name is either null or unique compared to the names of other /// components in the container. /// protected virtual void ValidateName(IComponent component, string name) { if (component == null) { throw new ArgumentNullException("component"); } if (name != null) { for (int i = 0; i < Math.Min(siteCount,sites.Length); i++) { ISite s = sites[ i ]; if (s != null && s.Name != null && string.Equals(s.Name, name, StringComparison.OrdinalIgnoreCase) && s.Component != component) { InheritanceAttribute inheritanceAttribute = (InheritanceAttribute)TypeDescriptor.GetAttributes(s.Component)[typeof(InheritanceAttribute)]; if(inheritanceAttribute.InheritanceLevel != InheritanceLevel.InheritedReadOnly) { throw new ArgumentException(SR.GetString(SR.DuplicateComponentName, name)); } } } } } private class Site : ISite { private IComponent component; private Container container; private String name; internal Site(IComponent component, Container container, String name) { this.component = component; this.container = container; this.name = name; } // The component sited by this component site. public IComponent Component { get { return component; } } // The container in which the component is sited. public IContainer Container { get { return container; } } public Object GetService(Type service) { return((service == typeof(ISite)) ? this : container.GetService(service)); } // Indicates whether the component is in design mode. public bool DesignMode { get { return false; } } // The name of the component. // public String Name { get { return name;} set { if (value == null || name == null || !value.Equals(name)) { // container.ValidateName(component, value); name = value; } } } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- AsyncOperation.cs
- ILGenerator.cs
- TriggerAction.cs
- Scene3D.cs
- ModulesEntry.cs
- BaseCodeDomTreeGenerator.cs
- objectresult_tresulttype.cs
- RemotingConfiguration.cs
- StringValidator.cs
- LoadedOrUnloadedOperation.cs
- PermissionSetTriple.cs
- ValidatingReaderNodeData.cs
- SecureEnvironment.cs
- ServicePointManagerElement.cs
- Crc32.cs
- Point3DAnimation.cs
- ISSmlParser.cs
- DataTemplateKey.cs
- ConfigXmlAttribute.cs
- ILGenerator.cs
- DiscoveryDocumentSearchPattern.cs
- CompilerState.cs
- DelegateOutArgument.cs
- WebPartDescription.cs
- PocoEntityKeyStrategy.cs
- ExtentKey.cs
- SerializationFieldInfo.cs
- ExtensionSurface.cs
- XmlDocumentSurrogate.cs
- ObservableCollection.cs
- UITypeEditor.cs
- DesignerToolStripControlHost.cs
- FixedSchema.cs
- RowCache.cs
- Token.cs
- StreamBodyWriter.cs
- hresults.cs
- Span.cs
- ReferencedAssembly.cs
- LocalFileSettingsProvider.cs
- MetroSerializationManager.cs
- CellRelation.cs
- DesignerOptionService.cs
- BufferedGraphicsManager.cs
- OdbcPermission.cs
- HighlightVisual.cs
- AnyReturnReader.cs
- ComplexPropertyEntry.cs
- EncodingNLS.cs
- MessagePropertyVariants.cs
- rsa.cs
- BitmapImage.cs
- RectangleConverter.cs
- UnSafeCharBuffer.cs
- MonthCalendar.cs
- RectangleGeometry.cs
- CellParaClient.cs
- NGCPageContentCollectionSerializerAsync.cs
- XPathMultyIterator.cs
- HttpWebRequest.cs
- filewebrequest.cs
- CompositionTarget.cs
- Cursor.cs
- HtmlFormParameterReader.cs
- SectionRecord.cs
- PackageRelationshipSelector.cs
- SecurityContext.cs
- AppearanceEditorPart.cs
- IconHelper.cs
- SuppressMergeCheckAttribute.cs
- TextEncodedRawTextWriter.cs
- WindowsUpDown.cs
- MachineSettingsSection.cs
- PartialCachingAttribute.cs
- FixedPosition.cs
- LineMetrics.cs
- ItemDragEvent.cs
- CoTaskMemUnicodeSafeHandle.cs
- InfoCardAsymmetricCrypto.cs
- DataGridViewToolTip.cs
- StringArrayConverter.cs
- InputScopeManager.cs
- BackgroundFormatInfo.cs
- ProtocolReflector.cs
- SafeUserTokenHandle.cs
- EntityDataSourceContextCreatingEventArgs.cs
- Application.cs
- SystemResources.cs
- XmlPropertyBag.cs
- PageCatalogPart.cs
- DnsElement.cs
- Renderer.cs
- MDIClient.cs
- SettingsAttributeDictionary.cs
- CellCreator.cs
- ReplyChannelBinder.cs
- Expressions.cs
- GenericRootAutomationPeer.cs
- TextClipboardData.cs
- FormCollection.cs