Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / CompMod / System / ComponentModel / Design / ServiceObjectContainer.cs / 1 / ServiceObjectContainer.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.ComponentModel.Design { using Microsoft.Win32; using System; using System.Collections; using System.Diagnostics; using System.Security.Permissions; ////// This is a simple implementation of IServiceContainer. /// [HostProtection(SharedState = true)] public class ServiceContainer : IServiceContainer, IDisposable { private Hashtable services; private IServiceProvider parentProvider; private static Type[] _defaultServices = new Type[] { typeof(IServiceContainer), typeof(ServiceContainer) }; private static TraceSwitch TRACESERVICE = new TraceSwitch("TRACESERVICE", "ServiceProvider: Trace service provider requests."); ////// Creates a new service object container. /// public ServiceContainer() { } ////// Creates a new service object container. /// public ServiceContainer(IServiceProvider parentProvider) { this.parentProvider = parentProvider; } ////// Retrieves the parent service container, or null /// if there is no parent container. /// private IServiceContainer Container { get { IServiceContainer container = null; if (parentProvider != null) { container = (IServiceContainer)parentProvider.GetService(typeof(IServiceContainer)); } return container; } } ////// This property returns the default services that are implemented directly on this IServiceContainer. /// the default implementation of this property is to return the IServiceContainer and ServiceContainer /// types. You may override this proeprty and return your own types, modifying the default behavior /// of GetService. /// protected virtual Type[] DefaultServices { get { return _defaultServices; } } ////// Our hashtable of services. The hashtable is demand /// created here. /// private Hashtable Services { get { if (services == null) { services = new Hashtable(); } return services; } } ////// Adds the given service to the service container. /// public void AddService(Type serviceType, object serviceInstance) { AddService(serviceType, serviceInstance, false); } ////// Adds the given service to the service container. /// public virtual void AddService(Type serviceType, object serviceInstance, bool promote) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Adding service (instance) " + serviceType.Name + ". Promoting: " + promote.ToString()); if (promote) { IServiceContainer container = Container; if (container != null) { Debug.Indent(); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Promoting to container"); Debug.Unindent(); container.AddService(serviceType, serviceInstance, promote); return; } } // We're going to add this locally. Ensure that the service instance // is correct. // if (serviceType == null) throw new ArgumentNullException("serviceType"); if (serviceInstance == null) throw new ArgumentNullException("serviceInstance"); if (!(serviceInstance is ServiceCreatorCallback) && !serviceInstance.GetType().IsCOMObject && !serviceType.IsAssignableFrom(serviceInstance.GetType())) { throw new ArgumentException(SR.GetString(SR.ErrorInvalidServiceInstance, serviceType.FullName)); } if (Services.ContainsKey(serviceType)) { throw new ArgumentException(SR.GetString(SR.ErrorServiceExists, serviceType.FullName), "serviceType"); } Services[serviceType] = serviceInstance; } ////// Adds the given service to the service container. /// public void AddService(Type serviceType, ServiceCreatorCallback callback) { AddService(serviceType, callback, false); } ////// Adds the given service to the service container. /// public virtual void AddService(Type serviceType, ServiceCreatorCallback callback, bool promote) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Adding service (callback) " + serviceType.Name + ". Promoting: " + promote.ToString()); if (promote) { IServiceContainer container = Container; if (container != null) { Debug.Indent(); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Promoting to container"); Debug.Unindent(); container.AddService(serviceType, callback, promote); return; } } // We're going to add this locally. Ensure that the service instance // is correct. // if (serviceType == null) throw new ArgumentNullException("serviceType"); if (callback == null) throw new ArgumentNullException("callback"); if (Services.ContainsKey(serviceType)) { throw new ArgumentException(SR.GetString(SR.ErrorServiceExists, serviceType.FullName), "serviceType"); } Services[serviceType] = callback; } ////// Disposes this service container. This also walks all instantiated services within the container /// and disposes any that implement IDisposable, and clears the service list. /// public void Dispose() { Dispose(true); } ////// Disposes this service container. This also walks all instantiated services within the container /// and disposes any that implement IDisposable, and clears the service list. /// protected virtual void Dispose(bool disposing) { if (disposing) { Hashtable serviceHash = services; services = null; if (serviceHash != null) { foreach(object o in serviceHash.Values) { if (o is IDisposable) { ((IDisposable)o).Dispose(); } } } } } ////// Retrieves the requested service. /// public virtual object GetService(Type serviceType) { object service = null; Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Searching for service " + serviceType.Name); Debug.Indent(); // Try locally. We first test for services we // implement and then look in our hashtable. // Type[] defaults = DefaultServices; for (int idx = 0; idx < defaults.Length; idx++) { if (serviceType == defaults[idx]) { service = this; break; } } if (service == null) { service = Services[serviceType]; } // Is the service a creator delegate? // if (service is ServiceCreatorCallback) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Encountered a callback. Invoking it"); service = ((ServiceCreatorCallback)service)(this, serviceType); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Callback return object: " + (service == null ? "(null)" : service.ToString())); if (service != null && !service.GetType().IsCOMObject && !serviceType.IsAssignableFrom(service.GetType())) { // Callback passed us a bad service. NULL it, rather than throwing an exception. // Callers here do not need to be prepared to handle bad callback implemetations. Debug.Fail("Object " + service.GetType().Name + " was returned from a service creator callback but it does not implement the registered type of " + serviceType.Name); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "**** Object does not implement service interface"); service = null; } // And replace the callback with our new service. // Services[serviceType] = service; } if (service == null && parentProvider != null) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Service unresolved. Trying parent"); service = parentProvider.GetService(serviceType); } #if DEBUG if (TRACESERVICE.TraceVerbose && service == null) { Debug.WriteLine("******************************************"); Debug.WriteLine("FAILED to resolve service " + serviceType.Name); Debug.WriteLine("AT: " + Environment.StackTrace); Debug.WriteLine("******************************************"); } #endif Debug.Unindent(); return service; } ////// Removes the given service type from the service container. /// public void RemoveService(Type serviceType) { RemoveService(serviceType, false); } ////// Removes the given service type from the service container. /// public virtual void RemoveService(Type serviceType, bool promote) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Removing service: " + serviceType.Name + ", Promote: " + promote.ToString()); if (promote) { IServiceContainer container = Container; if (container != null) { Debug.Indent(); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Invoking parent container"); Debug.Unindent(); container.RemoveService(serviceType, promote); return; } } // We're going to remove this from our local list. // if (serviceType == null) throw new ArgumentNullException("serviceType"); Services.Remove(serviceType); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.ComponentModel.Design { using Microsoft.Win32; using System; using System.Collections; using System.Diagnostics; using System.Security.Permissions; ////// This is a simple implementation of IServiceContainer. /// [HostProtection(SharedState = true)] public class ServiceContainer : IServiceContainer, IDisposable { private Hashtable services; private IServiceProvider parentProvider; private static Type[] _defaultServices = new Type[] { typeof(IServiceContainer), typeof(ServiceContainer) }; private static TraceSwitch TRACESERVICE = new TraceSwitch("TRACESERVICE", "ServiceProvider: Trace service provider requests."); ////// Creates a new service object container. /// public ServiceContainer() { } ////// Creates a new service object container. /// public ServiceContainer(IServiceProvider parentProvider) { this.parentProvider = parentProvider; } ////// Retrieves the parent service container, or null /// if there is no parent container. /// private IServiceContainer Container { get { IServiceContainer container = null; if (parentProvider != null) { container = (IServiceContainer)parentProvider.GetService(typeof(IServiceContainer)); } return container; } } ////// This property returns the default services that are implemented directly on this IServiceContainer. /// the default implementation of this property is to return the IServiceContainer and ServiceContainer /// types. You may override this proeprty and return your own types, modifying the default behavior /// of GetService. /// protected virtual Type[] DefaultServices { get { return _defaultServices; } } ////// Our hashtable of services. The hashtable is demand /// created here. /// private Hashtable Services { get { if (services == null) { services = new Hashtable(); } return services; } } ////// Adds the given service to the service container. /// public void AddService(Type serviceType, object serviceInstance) { AddService(serviceType, serviceInstance, false); } ////// Adds the given service to the service container. /// public virtual void AddService(Type serviceType, object serviceInstance, bool promote) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Adding service (instance) " + serviceType.Name + ". Promoting: " + promote.ToString()); if (promote) { IServiceContainer container = Container; if (container != null) { Debug.Indent(); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Promoting to container"); Debug.Unindent(); container.AddService(serviceType, serviceInstance, promote); return; } } // We're going to add this locally. Ensure that the service instance // is correct. // if (serviceType == null) throw new ArgumentNullException("serviceType"); if (serviceInstance == null) throw new ArgumentNullException("serviceInstance"); if (!(serviceInstance is ServiceCreatorCallback) && !serviceInstance.GetType().IsCOMObject && !serviceType.IsAssignableFrom(serviceInstance.GetType())) { throw new ArgumentException(SR.GetString(SR.ErrorInvalidServiceInstance, serviceType.FullName)); } if (Services.ContainsKey(serviceType)) { throw new ArgumentException(SR.GetString(SR.ErrorServiceExists, serviceType.FullName), "serviceType"); } Services[serviceType] = serviceInstance; } ////// Adds the given service to the service container. /// public void AddService(Type serviceType, ServiceCreatorCallback callback) { AddService(serviceType, callback, false); } ////// Adds the given service to the service container. /// public virtual void AddService(Type serviceType, ServiceCreatorCallback callback, bool promote) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Adding service (callback) " + serviceType.Name + ". Promoting: " + promote.ToString()); if (promote) { IServiceContainer container = Container; if (container != null) { Debug.Indent(); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Promoting to container"); Debug.Unindent(); container.AddService(serviceType, callback, promote); return; } } // We're going to add this locally. Ensure that the service instance // is correct. // if (serviceType == null) throw new ArgumentNullException("serviceType"); if (callback == null) throw new ArgumentNullException("callback"); if (Services.ContainsKey(serviceType)) { throw new ArgumentException(SR.GetString(SR.ErrorServiceExists, serviceType.FullName), "serviceType"); } Services[serviceType] = callback; } ////// Disposes this service container. This also walks all instantiated services within the container /// and disposes any that implement IDisposable, and clears the service list. /// public void Dispose() { Dispose(true); } ////// Disposes this service container. This also walks all instantiated services within the container /// and disposes any that implement IDisposable, and clears the service list. /// protected virtual void Dispose(bool disposing) { if (disposing) { Hashtable serviceHash = services; services = null; if (serviceHash != null) { foreach(object o in serviceHash.Values) { if (o is IDisposable) { ((IDisposable)o).Dispose(); } } } } } ////// Retrieves the requested service. /// public virtual object GetService(Type serviceType) { object service = null; Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Searching for service " + serviceType.Name); Debug.Indent(); // Try locally. We first test for services we // implement and then look in our hashtable. // Type[] defaults = DefaultServices; for (int idx = 0; idx < defaults.Length; idx++) { if (serviceType == defaults[idx]) { service = this; break; } } if (service == null) { service = Services[serviceType]; } // Is the service a creator delegate? // if (service is ServiceCreatorCallback) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Encountered a callback. Invoking it"); service = ((ServiceCreatorCallback)service)(this, serviceType); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Callback return object: " + (service == null ? "(null)" : service.ToString())); if (service != null && !service.GetType().IsCOMObject && !serviceType.IsAssignableFrom(service.GetType())) { // Callback passed us a bad service. NULL it, rather than throwing an exception. // Callers here do not need to be prepared to handle bad callback implemetations. Debug.Fail("Object " + service.GetType().Name + " was returned from a service creator callback but it does not implement the registered type of " + serviceType.Name); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "**** Object does not implement service interface"); service = null; } // And replace the callback with our new service. // Services[serviceType] = service; } if (service == null && parentProvider != null) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Service unresolved. Trying parent"); service = parentProvider.GetService(serviceType); } #if DEBUG if (TRACESERVICE.TraceVerbose && service == null) { Debug.WriteLine("******************************************"); Debug.WriteLine("FAILED to resolve service " + serviceType.Name); Debug.WriteLine("AT: " + Environment.StackTrace); Debug.WriteLine("******************************************"); } #endif Debug.Unindent(); return service; } ////// Removes the given service type from the service container. /// public void RemoveService(Type serviceType) { RemoveService(serviceType, false); } ////// Removes the given service type from the service container. /// public virtual void RemoveService(Type serviceType, bool promote) { Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Removing service: " + serviceType.Name + ", Promote: " + promote.ToString()); if (promote) { IServiceContainer container = Container; if (container != null) { Debug.Indent(); Debug.WriteLineIf(TRACESERVICE.TraceVerbose, "Invoking parent container"); Debug.Unindent(); container.RemoveService(serviceType, promote); return; } } // We're going to remove this from our local list. // if (serviceType == null) throw new ArgumentNullException("serviceType"); Services.Remove(serviceType); } } } // 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
- Trace.cs
- CallSiteBinder.cs
- SqlProviderUtilities.cs
- SortFieldComparer.cs
- CryptoConfig.cs
- EpmContentSerializerBase.cs
- WmfPlaceableFileHeader.cs
- CultureSpecificCharacterBufferRange.cs
- CodeCompileUnit.cs
- TableItemPatternIdentifiers.cs
- ReadOnlyDataSourceView.cs
- MailAddressParser.cs
- ContentDisposition.cs
- ComboBox.cs
- ContextProperty.cs
- InheritanceAttribute.cs
- RealizationDrawingContextWalker.cs
- ColumnMapVisitor.cs
- Util.cs
- ExpressionVisitor.cs
- TdsParserStaticMethods.cs
- AddInServer.cs
- Profiler.cs
- HttpsChannelListener.cs
- Keyboard.cs
- WebHttpDispatchOperationSelectorData.cs
- COAUTHIDENTITY.cs
- MimeMultiPart.cs
- _SslState.cs
- StateMachineExecutionState.cs
- ApplicationProxyInternal.cs
- Constants.cs
- CompiledELinqQueryState.cs
- MSHTMLHost.cs
- CustomGrammar.cs
- FileFormatException.cs
- ConsumerConnectionPointCollection.cs
- WasEndpointConfigContainer.cs
- RequiredAttributeAttribute.cs
- XPathChildIterator.cs
- SecurityTokenParameters.cs
- AuthenticationSchemesHelper.cs
- DynamicQueryStringParameter.cs
- Blend.cs
- FixedSOMLineCollection.cs
- BuilderPropertyEntry.cs
- ExtensibleClassFactory.cs
- ResXBuildProvider.cs
- CompleteWizardStep.cs
- WindowsListViewGroup.cs
- ChannelTerminatedException.cs
- SByte.cs
- SchemaHelper.cs
- ReferentialConstraint.cs
- SpellerInterop.cs
- UpdateException.cs
- ListViewGroupItemCollection.cs
- OdbcParameterCollection.cs
- GridLengthConverter.cs
- AssemblyBuilder.cs
- CatalogPartChrome.cs
- MILUtilities.cs
- GenericIdentity.cs
- altserialization.cs
- ActiveDocumentEvent.cs
- EntityDataSourceMemberPath.cs
- SingletonChannelAcceptor.cs
- SerializationSectionGroup.cs
- RelatedImageListAttribute.cs
- FontFamilyIdentifier.cs
- SID.cs
- FileDataSourceCache.cs
- SoapParser.cs
- SafeThreadHandle.cs
- XsltInput.cs
- MgmtConfigurationRecord.cs
- FormViewDeleteEventArgs.cs
- RequestDescription.cs
- SizeValueSerializer.cs
- MessageVersionConverter.cs
- MimeBasePart.cs
- ChannelOptions.cs
- Executor.cs
- FileSecurity.cs
- DiscoveryOperationContextExtension.cs
- PageEventArgs.cs
- BridgeDataReader.cs
- AtomPub10CategoriesDocumentFormatter.cs
- FilteredAttributeCollection.cs
- FormsAuthenticationTicket.cs
- EditingCoordinator.cs
- AsyncOperation.cs
- ReflectionPermission.cs
- ItemContainerPattern.cs
- ProvidersHelper.cs
- UnionCodeGroup.cs
- ADMembershipUser.cs
- Point3DConverter.cs
- ItemCheckedEvent.cs
- BinHexEncoder.cs