Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Wmi / managed / System / Management / ManagementNamedValueCollection.cs / 1305376 / ManagementNamedValueCollection.cs
using System; using System.Collections; using System.Collections.Specialized; using WbemClient_v1; using System.Runtime.Serialization; namespace System.Management { //CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC// ////// //CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC// public class ManagementNamedValueCollection : NameObjectCollectionBase { // Notification of when the content of this collection changes internal event IdentifierChangedEventHandler IdentifierChanged; //Fires IdentifierChanged event private void FireIdentifierChanged() { if (IdentifierChanged != null) IdentifierChanged(this, null); } //default constructor ///Represents a collection of named values /// suitable for use as context information to WMI operations. The /// names are case-insensitive. ////// Initializes a new instance /// of the ///class. /// /// public ManagementNamedValueCollection() { } ///Initializes a new instance of the ///class, which is empty. This is /// the default constructor. /// /// TheInitializes a new instance of the ///class that is serializable /// and uses the specified /// and . to populate with data. /// The destination (see ) for this serialization. protected ManagementNamedValueCollection(SerializationInfo info, StreamingContext context) : base(info, context) { } /// /// internal IWbemContext GetContext() { IWbemContext wbemContext = null; // Only build a context if we have something to put in it if (0 < Count) { int status = (int)ManagementStatus.NoError; try { wbemContext = (IWbemContext) new WbemContext (); foreach (string name in this) { object val = base.BaseGet(name); status = wbemContext.SetValue_ (name, 0, ref val); if ((status & 0x80000000) != 0) { break; } } } catch {} // } return wbemContext; } ///Internal method to return an IWbemContext representation /// of the named value collection. ////// /// The name of the new value. /// The value to be associated with the name. public void Add (string name, object value) { // Remove any old entry try { base.BaseRemove (name); } catch {} base.BaseAdd (name, value); FireIdentifierChanged (); } ///Adds a single-named value to the collection. ////// /// The name of the value to be removed. public void Remove (string name) { base.BaseRemove (name); FireIdentifierChanged (); } ///Removes a single-named value from the collection. /// If the collection does not contain an element with the /// specified name, the collection remains unchanged and no /// exception is thrown. ////// public void RemoveAll () { base.BaseClear (); FireIdentifierChanged (); } ///Removes all entries from the collection. ////// ///Creates a clone of the collection. Individual values /// are cloned. If a value does not support cloning, then a ////// is thrown. /// The new copy of the collection. /// public ManagementNamedValueCollection Clone () { ManagementNamedValueCollection nvc = new ManagementNamedValueCollection(); foreach (string name in this) { // If we can clone the value, do so. Otherwise throw. object val = base.BaseGet (name); if (null != val) { Type valueType = val.GetType (); if (valueType.IsByRef) { try { object clonedValue = ((ICloneable)val).Clone (); nvc.Add (name, clonedValue); } catch { throw new NotSupportedException (); } } else { nvc.Add (name, val); } } else nvc.Add (name, null); } return nvc; } ////// /// The name of the value to be returned. ///Returns the value associated with the specified name from this collection. ////// public object this[string name] { get { return base.BaseGet(name); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System; using System.Collections; using System.Collections.Specialized; using WbemClient_v1; using System.Runtime.Serialization; namespace System.Management { //CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC// ///An ///containing the /// value of the specified item in this collection. /// //CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC// public class ManagementNamedValueCollection : NameObjectCollectionBase { // Notification of when the content of this collection changes internal event IdentifierChangedEventHandler IdentifierChanged; //Fires IdentifierChanged event private void FireIdentifierChanged() { if (IdentifierChanged != null) IdentifierChanged(this, null); } //default constructor ///Represents a collection of named values /// suitable for use as context information to WMI operations. The /// names are case-insensitive. ////// Initializes a new instance /// of the ///class. /// /// public ManagementNamedValueCollection() { } ///Initializes a new instance of the ///class, which is empty. This is /// the default constructor. /// /// TheInitializes a new instance of the ///class that is serializable /// and uses the specified /// and . to populate with data. /// The destination (see ) for this serialization. protected ManagementNamedValueCollection(SerializationInfo info, StreamingContext context) : base(info, context) { } /// /// internal IWbemContext GetContext() { IWbemContext wbemContext = null; // Only build a context if we have something to put in it if (0 < Count) { int status = (int)ManagementStatus.NoError; try { wbemContext = (IWbemContext) new WbemContext (); foreach (string name in this) { object val = base.BaseGet(name); status = wbemContext.SetValue_ (name, 0, ref val); if ((status & 0x80000000) != 0) { break; } } } catch {} // } return wbemContext; } ///Internal method to return an IWbemContext representation /// of the named value collection. ////// /// The name of the new value. /// The value to be associated with the name. public void Add (string name, object value) { // Remove any old entry try { base.BaseRemove (name); } catch {} base.BaseAdd (name, value); FireIdentifierChanged (); } ///Adds a single-named value to the collection. ////// /// The name of the value to be removed. public void Remove (string name) { base.BaseRemove (name); FireIdentifierChanged (); } ///Removes a single-named value from the collection. /// If the collection does not contain an element with the /// specified name, the collection remains unchanged and no /// exception is thrown. ////// public void RemoveAll () { base.BaseClear (); FireIdentifierChanged (); } ///Removes all entries from the collection. ////// ///Creates a clone of the collection. Individual values /// are cloned. If a value does not support cloning, then a ////// is thrown. /// The new copy of the collection. /// public ManagementNamedValueCollection Clone () { ManagementNamedValueCollection nvc = new ManagementNamedValueCollection(); foreach (string name in this) { // If we can clone the value, do so. Otherwise throw. object val = base.BaseGet (name); if (null != val) { Type valueType = val.GetType (); if (valueType.IsByRef) { try { object clonedValue = ((ICloneable)val).Clone (); nvc.Add (name, clonedValue); } catch { throw new NotSupportedException (); } } else { nvc.Add (name, val); } } else nvc.Add (name, null); } return nvc; } ////// /// The name of the value to be returned. ///Returns the value associated with the specified name from this collection. ////// public object this[string name] { get { return base.BaseGet(name); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.An ///containing the /// value of the specified item in this collection.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- StandardCommands.cs
- CodeDOMProvider.cs
- DetailsViewRow.cs
- _BasicClient.cs
- DataRowExtensions.cs
- TraceContextEventArgs.cs
- ValueUtilsSmi.cs
- InitializationEventAttribute.cs
- PanelStyle.cs
- DependencyProperty.cs
- SqlServices.cs
- listitem.cs
- DefaultParameterValueAttribute.cs
- XmlWellformedWriter.cs
- DbConnectionInternal.cs
- ImageClickEventArgs.cs
- SecondaryViewProvider.cs
- ObjectListDataBindEventArgs.cs
- PasswordTextNavigator.cs
- ToolStripItemDataObject.cs
- AttachedAnnotation.cs
- ObjectContext.cs
- CreateUserWizardAutoFormat.cs
- SafeUserTokenHandle.cs
- ChannelBinding.cs
- Vector3D.cs
- PeerApplicationLaunchInfo.cs
- Timeline.cs
- ThousandthOfEmRealPoints.cs
- UmAlQuraCalendar.cs
- CodeDirectionExpression.cs
- DataBoundLiteralControl.cs
- DecoratedNameAttribute.cs
- ChainedAsyncResult.cs
- Model3DGroup.cs
- RowType.cs
- MobileErrorInfo.cs
- SmiEventStream.cs
- Overlapped.cs
- MD5CryptoServiceProvider.cs
- BitmapDownload.cs
- PocoPropertyAccessorStrategy.cs
- RequestCachePolicy.cs
- TextBoxAutoCompleteSourceConverter.cs
- BindingExpressionBase.cs
- ModelPropertyCollectionImpl.cs
- ServiceModelConfigurationSection.cs
- HtmlMeta.cs
- ToolbarAUtomationPeer.cs
- XmlRawWriter.cs
- WebBrowserSiteBase.cs
- RestHandlerFactory.cs
- UserPreferenceChangedEventArgs.cs
- DeadCharTextComposition.cs
- DataGridViewElement.cs
- EnumValAlphaComparer.cs
- WmlCalendarAdapter.cs
- _RegBlobWebProxyDataBuilder.cs
- WebPartExportVerb.cs
- ObjectCacheSettings.cs
- SmtpNetworkElement.cs
- FileReader.cs
- DataGridAutoFormatDialog.cs
- RemotingException.cs
- SqlPersonalizationProvider.cs
- UInt16Converter.cs
- ProcessModelSection.cs
- TimeSpanStorage.cs
- CancelEventArgs.cs
- FontNamesConverter.cs
- XDRSchema.cs
- EllipticalNodeOperations.cs
- Activity.cs
- PageBuildProvider.cs
- Attributes.cs
- SqlXmlStorage.cs
- Compilation.cs
- FontFamily.cs
- ProxyFragment.cs
- StackSpiller.Bindings.cs
- ClrProviderManifest.cs
- TransactionScope.cs
- ClientTarget.cs
- WSFederationHttpSecurity.cs
- XamlTypeMapper.cs
- EventLogPermissionAttribute.cs
- TextElementCollection.cs
- UndoUnit.cs
- CreateUserWizardAutoFormat.cs
- SuppressMessageAttribute.cs
- CustomCategoryAttribute.cs
- CacheEntry.cs
- SQLDoubleStorage.cs
- NegotiationTokenAuthenticatorStateCache.cs
- StrokeNodeEnumerator.cs
- BamlLocalizerErrorNotifyEventArgs.cs
- Italic.cs
- Compilation.cs
- MonitorWrapper.cs
- ContainerActivationHelper.cs