You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			620 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			620 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //------------------------------------------------------------- | |||
|  | // <copyright company=’Microsoft Corporation’> | |||
|  | //   Copyright © Microsoft Corporation. All Rights Reserved. | |||
|  | // </copyright> | |||
|  | //------------------------------------------------------------- | |||
|  | // @owner=alexgor, deliant, victark | |||
|  | 
 | |||
|  | using System; | |||
|  | using System.Collections.Generic; | |||
|  | using System.Collections.ObjectModel; | |||
|  | using System.Text; | |||
|  | using System.Globalization; | |||
|  | using System.Diagnostics.CodeAnalysis; | |||
|  | using System.Collections; | |||
|  | 
 | |||
|  | #if Microsoft_CONTROL | |||
|  | namespace System.Windows.Forms.DataVisualization.Charting | |||
|  | #else | |||
|  | namespace System.Web.UI.DataVisualization.Charting | |||
|  | #endif | |||
|  | { | |||
|  | 
 | |||
|  |     /// <summary> | |||
|  |     /// Base class for all chart element collections | |||
|  |     /// </summary> | |||
|  | #if ASPPERM_35 | |||
|  | 	[AspNetHostingPermission(System.Security.Permissions.SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)] | |||
|  |     [AspNetHostingPermission(System.Security.Permissions.SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)] | |||
|  | #endif | |||
|  |     public abstract class ChartElementCollection<T> : Collection<T>, IChartElement, IDisposable | |||
|  |         where T : ChartElement | |||
|  |     { | |||
|  |         #region Member variables | |||
|  | 
 | |||
|  |         private IChartElement _parent = null; | |||
|  |         private CommonElements _common = null; | |||
|  |         internal int _suspendUpdates = 0; | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Properties | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets or sets the parent. | |||
|  |         /// </summary> | |||
|  |         internal IChartElement Parent | |||
|  |         { | |||
|  |             get { return _parent; } | |||
|  |             set | |||
|  |             { | |||
|  |                 _parent = value; | |||
|  |                 Invalidate(); | |||
|  |             } | |||
|  |         } | |||
|  |         /// <summary> | |||
|  |         /// Gets the CommonElements of the chart. | |||
|  |         /// </summary> | |||
|  |         internal CommonElements Common | |||
|  |         { | |||
|  |             get | |||
|  |             { | |||
|  |                 if (_common == null && _parent != null) | |||
|  |                 { | |||
|  |                     _common = _parent.Common; | |||
|  |                 } | |||
|  |                 return _common; | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets the chart. | |||
|  |         /// </summary> | |||
|  |         internal Chart Chart | |||
|  |         { | |||
|  |             get | |||
|  |             { | |||
|  |                 if (Common != null) | |||
|  |                     return Common.Chart; | |||
|  |                 else | |||
|  |                     return null; | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets the items as List<T>. Use this property to perform advanced List specific operations (Sorting, etc) | |||
|  |         /// </summary> | |||
|  |         internal List<T> ItemList  | |||
|  |         { | |||
|  |             get { return Items as List<T>; } | |||
|  |         } | |||
|  | 
 | |||
|  |         internal bool IsSuspended | |||
|  |         { | |||
|  |             get { return _suspendUpdates > 0; } | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Constructors | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Initializes a new instance of the <see cref="ChartElementCollection<T>"/> class. | |||
|  |         /// </summary> | |||
|  |         /// <param name="parent">The parent chart element.</param> | |||
|  |         internal ChartElementCollection(IChartElement parent) | |||
|  |         { | |||
|  |             _parent = parent; | |||
|  |         } | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Methods | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Forces the invalidation of the parent chart element | |||
|  |         /// </summary> | |||
|  |         public virtual void Invalidate() | |||
|  |         { | |||
|  |             if (_parent != null && !IsSuspended) | |||
|  |                 _parent.Invalidate(); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Suspends invalidation | |||
|  |         /// </summary> | |||
|  |         public virtual void SuspendUpdates()  | |||
|  |         { | |||
|  |             _suspendUpdates++; | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Resumes invalidation. | |||
|  |         /// </summary> | |||
|  |         public virtual void ResumeUpdates() | |||
|  |         { | |||
|  |             if (_suspendUpdates>0) | |||
|  |                 _suspendUpdates--; | |||
|  | 
 | |||
|  |             if (_suspendUpdates==0) | |||
|  |                 this.Invalidate();  | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Removes all elements from the <see cref="T:System.Collections.ObjectModel.Collection`1"/>. | |||
|  |         /// </summary> | |||
|  |         [SuppressMessage("Microsoft.Security", "CA2123:OverrideLinkDemandsShouldBeIdenticalToBase")] | |||
|  |         protected override void ClearItems() | |||
|  |         { | |||
|  |             SuspendUpdates(); | |||
|  |             while (this.Count > 0) | |||
|  |             { | |||
|  |                 this.RemoveItem(0); | |||
|  |             } | |||
|  |             ResumeUpdates(); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Deinitializes the specified item. | |||
|  |         /// </summary> | |||
|  |         /// <param name="item">The item.</param> | |||
|  |         internal virtual void Deinitialize( T item) | |||
|  |         { | |||
|  | 
 | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Initializes the specified item. | |||
|  |         /// </summary> | |||
|  |         /// <param name="item">The item.</param> | |||
|  |         internal virtual void Initialize(T item) | |||
|  |         { | |||
|  | 
 | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Removes the element at the specified index of the <see cref="T:System.Collections.ObjectModel.Collection`1"/>. | |||
|  |         /// </summary> | |||
|  |         /// <param name="index">The zero-based index of the element to remove.</param> | |||
|  |         [SuppressMessage("Microsoft.Security", "CA2123:OverrideLinkDemandsShouldBeIdenticalToBase")] | |||
|  |         protected override void RemoveItem(int index) | |||
|  |         { | |||
|  |             this.Deinitialize(this[index]); | |||
|  |             this[index].Parent = null; | |||
|  |             base.RemoveItem(index); | |||
|  |             Invalidate(); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Inserts an element into the <see cref="T:System.Collections.ObjectModel.Collection`1"/> at the specified index. | |||
|  |         /// </summary> | |||
|  |         /// <param name="index">The zero-based index at which <paramref name="item"/> should be inserted.</param> | |||
|  |         /// <param name="item">The object to insert. The value can be null for reference types.</param> | |||
|  |         [SuppressMessage("Microsoft.Security", "CA2123:OverrideLinkDemandsShouldBeIdenticalToBase")] | |||
|  |         protected override void InsertItem(int index, T item) | |||
|  |         { | |||
|  |             this.Initialize(item); | |||
|  |             item.Parent = this; | |||
|  |             base.InsertItem(index, item); | |||
|  |             Invalidate(); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Replaces the element at the specified index. | |||
|  |         /// </summary> | |||
|  |         /// <param name="index">The zero-based index of the element to replace.</param> | |||
|  |         /// <param name="item">The new value for the element at the specified index. The value can be null for reference types.</param> | |||
|  |         [SuppressMessage("Microsoft.Security", "CA2123:OverrideLinkDemandsShouldBeIdenticalToBase")] | |||
|  |         protected override void SetItem(int index, T item) | |||
|  |         { | |||
|  |             this.Initialize(item); | |||
|  |             item.Parent = this; | |||
|  |             base.SetItem(index, item); | |||
|  |             Invalidate(); | |||
|  |         } | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region IChartElement Members | |||
|  | 
 | |||
|  |         IChartElement IChartElement.Parent | |||
|  |         { | |||
|  |             get { return this.Parent; } | |||
|  |             set { this.Parent = value; } | |||
|  |         } | |||
|  | 
 | |||
|  |         void IChartElement.Invalidate() | |||
|  |         { | |||
|  |             this.Invalidate(); | |||
|  |         } | |||
|  | 
 | |||
|  |         CommonElements IChartElement.Common | |||
|  |         { | |||
|  |             get{ return this.Common; } | |||
|  |         } | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region IDisposable Members | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Releases unmanaged and - optionally - managed resources | |||
|  |         /// </summary> | |||
|  |         /// <param name="disposing"><c>true</c> to release both managed and unmanaged resources; <c>false</c> to release only unmanaged resources.</param> | |||
|  |         protected virtual void Dispose(bool disposing) | |||
|  |         { | |||
|  |             if (disposing) | |||
|  |             { | |||
|  |                 // Dispose managed resources | |||
|  |                 foreach (T element in this) | |||
|  |                 { | |||
|  |                     element.Dispose(); | |||
|  |                 } | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Performs freeing, releasing, or resetting managed resources. | |||
|  |         /// </summary> | |||
|  |         [SuppressMessage("Microsoft.Security", "CA2123:OverrideLinkDemandsShouldBeIdenticalToBase")] | |||
|  |         public void Dispose() | |||
|  |         { | |||
|  |             this.Dispose(true); | |||
|  |             GC.SuppressFinalize(this); | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |     } | |||
|  | 
 | |||
|  |     /// <summary> | |||
|  |     /// Base class for all collections of named chart elements. Performs the name management and enforces the uniquness of the names | |||
|  |     /// </summary> | |||
|  |     /// <typeparam name="T"></typeparam> | |||
|  | #if ASPPERM_35 | |||
|  | 	[AspNetHostingPermission(System.Security.Permissions.SecurityAction.InheritanceDemand, Level = AspNetHostingPermissionLevel.Minimal)] | |||
|  |     [AspNetHostingPermission(System.Security.Permissions.SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)] | |||
|  | #endif | |||
|  |     public abstract class ChartNamedElementCollection<T> : ChartElementCollection<T>, INameController | |||
|  |         where T : ChartNamedElement | |||
|  |     { | |||
|  | 
 | |||
|  |         #region Fields | |||
|  |         private List<T> _cachedState = null; | |||
|  |         private int _disableDeleteCount = 0; | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Properties | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets the name prefix that is used to create unique chart element names. | |||
|  |         /// </summary> | |||
|  |         /// <value>The default name prefix of the chart elements stored in the collection.</value> | |||
|  |         protected virtual string NamePrefix | |||
|  |         { | |||
|  |             get { return typeof(T).Name; } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets or sets the chart element with the specified name. | |||
|  |         /// </summary> | |||
|  |         /// <value></value> | |||
|  |         public T this[string name] | |||
|  |         { | |||
|  |             get | |||
|  |             { | |||
|  |                 int index = this.IndexOf(name); | |||
|  |                 if (index != -1) | |||
|  |                 { | |||
|  |                     return this[index]; | |||
|  |                 } | |||
|  |                 throw new ArgumentException(SR.ExceptionNameNotFound(name, this.GetType().Name)); | |||
|  |             } | |||
|  |             set | |||
|  |             { | |||
|  |                 int nameIndex = this.IndexOf(name); | |||
|  |                 int itemIndex = this.IndexOf(value); | |||
|  |                 bool nameFound = nameIndex > -1; | |||
|  |                 bool itemFound = itemIndex > -1; | |||
|  | 
 | |||
|  |                 if (!nameFound && !itemFound) | |||
|  |                     this.Add(value); | |||
|  | 
 | |||
|  |                 else if (nameFound && !itemFound) | |||
|  |                     this[nameIndex] = value; | |||
|  | 
 | |||
|  |                 else if (!nameFound && itemFound) | |||
|  |                     throw new ArgumentException(SR.ExceptionNameAlreadyExistsInCollection(name, this.GetType().Name)); | |||
|  |                      | |||
|  |                 else if (nameFound && itemFound && nameIndex != itemIndex) | |||
|  |                     throw new ArgumentException(SR.ExceptionNameAlreadyExistsInCollection(name, this.GetType().Name)); | |||
|  |                      | |||
|  |             } | |||
|  |         } | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Constructors | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Initializes a new instance of the <see cref="ChartNamedElementCollection<T>"/> class. | |||
|  |         /// </summary> | |||
|  |         /// <param name="parent">The parent chart element.</param> | |||
|  |         internal ChartNamedElementCollection(IChartElement parent) | |||
|  |             : base(parent) | |||
|  |         { | |||
|  |         } | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Events | |||
|  | 
 | |||
|  |         internal event EventHandler<NameReferenceChangedEventArgs> NameReferenceChanged; | |||
|  |         internal event EventHandler<NameReferenceChangedEventArgs> NameReferenceChanging; | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region Methods | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Determines whether the chart element with the specified name already exists in the collection. | |||
|  |         /// </summary> | |||
|  |         /// <param name="name">The new chart element name.</param> | |||
|  |         /// <returns> | |||
|  |         /// 	<c>true</c> if new chart element name is unique; otherwise, <c>false</c>. | |||
|  |         /// </returns> | |||
|  |         public virtual bool IsUniqueName(string name) | |||
|  |         { | |||
|  |             return FindByName(name)==null; | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Finds the unique name for a new element being added to the collection | |||
|  |         /// </summary> | |||
|  |         /// <returns>Next unique chart element name</returns> | |||
|  |         public virtual string NextUniqueName() | |||
|  |         { | |||
|  |             // Find unique name | |||
|  |             string result = string.Empty; | |||
|  |             string prefix = this.NamePrefix; | |||
|  |             for (int i = 1; i < System.Int32.MaxValue; i++) | |||
|  |             { | |||
|  |                 result = prefix + i.ToString(CultureInfo.InvariantCulture); | |||
|  |                 // Check whether the name is unique | |||
|  |                 if (IsUniqueName(result)) | |||
|  |                 { | |||
|  |                     break; | |||
|  |                 } | |||
|  |             } | |||
|  |             return result; | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Indexes the of chart element with the specified name. | |||
|  |         /// </summary> | |||
|  |         /// <param name="name">The name.</param> | |||
|  |         /// <returns></returns> | |||
|  |         public int IndexOf(string name) | |||
|  |         { | |||
|  |             int i = 0; | |||
|  |             foreach (T namedObj in this) | |||
|  |             { | |||
|  |                 if (namedObj.Name == name) | |||
|  |                     return i; | |||
|  |                 i++; | |||
|  |             } | |||
|  |             return -1; | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Verifies the name reference to a chart named element stored in this collection and throws the argument exception if its not valid. | |||
|  |         /// </summary> | |||
|  |         /// <param name="name">Chart element name.</param> | |||
|  |         internal void VerifyNameReference(string name) | |||
|  |         { | |||
|  |             if (Chart!=null && !Chart.serializing && !IsNameReferenceValid(name)) | |||
|  |                 throw new ArgumentException(SR.ExceptionNameNotFound(name, this.GetType().Name)); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Verifies the name reference to a chart named element stored in this collection. | |||
|  |         /// </summary> | |||
|  |         /// <param name="name">Chart element name.</param> | |||
|  |         internal bool IsNameReferenceValid(string name) | |||
|  |         { | |||
|  |             return  String.IsNullOrEmpty(name) ||  | |||
|  |                     name == Constants.NotSetValue || | |||
|  |                     IndexOf(name) >= 0; | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Finds the chart element by the name. | |||
|  |         /// </summary> | |||
|  |         /// <param name="name">The name.</param> | |||
|  |         /// <returns></returns> | |||
|  |         public virtual T FindByName(string name) | |||
|  |         { | |||
|  |             foreach (T namedObj in this) | |||
|  |             { | |||
|  |                 if (namedObj.Name == name) | |||
|  |                     return namedObj; | |||
|  |             } | |||
|  |             return null; | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Inserts the specified item in the collection at the specified index. | |||
|  |         /// </summary> | |||
|  |         /// <param name="index">The zero-based index where the item is to be inserted.</param> | |||
|  |         /// <param name="item">The object to insert.</param> | |||
|  |         protected override void InsertItem(int index, T item) | |||
|  |         { | |||
|  |             if (String.IsNullOrEmpty(item.Name)) | |||
|  |                 item.Name = this.NextUniqueName(); | |||
|  |             else if (!IsUniqueName(item.Name)) | |||
|  |                 throw new ArgumentException(SR.ExceptionNameAlreadyExistsInCollection(item.Name, this.GetType().Name)); | |||
|  | 
 | |||
|  |             //If the item references other named references we might need to fix the references | |||
|  |             FixNameReferences(item); | |||
|  | 
 | |||
|  |             base.InsertItem(index, item); | |||
|  | 
 | |||
|  |             if (this.Count == 1 && item != null) | |||
|  |             {  | |||
|  |                 // First element is added to the list -> fire the NameReferenceChanged event to update all the dependent elements | |||
|  |                 ((INameController)this).OnNameReferenceChanged(new NameReferenceChangedEventArgs(null, item)); | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Replaces the element at the specified index. | |||
|  |         /// </summary> | |||
|  |         /// <param name="index">The zero-based index of the element to replace.</param> | |||
|  |         /// <param name="item">The new value for the element at the specified index.</param> | |||
|  |         protected override void SetItem(int index, T item) | |||
|  |         { | |||
|  |             if (String.IsNullOrEmpty(item.Name)) | |||
|  |                 item.Name = this.NextUniqueName(); | |||
|  |             else if (!IsUniqueName(item.Name) && IndexOf(item.Name) != index) | |||
|  |                 throw new ArgumentException(SR.ExceptionNameAlreadyExistsInCollection(item.Name, this.GetType().Name)); | |||
|  | 
 | |||
|  |             //If the item references other named references we might need to fix the references | |||
|  |             FixNameReferences(item); | |||
|  | 
 | |||
|  |             // Remember the removedElement | |||
|  |             ChartNamedElement removedElement = index<Count ? this[index] : null; | |||
|  |              | |||
|  |             ((INameController)this).OnNameReferenceChanging(new NameReferenceChangedEventArgs(removedElement, item)); | |||
|  |             base.SetItem(index, item); | |||
|  |             // Fire the NameReferenceChanged event to update all the dependent elements | |||
|  |             ((INameController)this).OnNameReferenceChanged(new NameReferenceChangedEventArgs(removedElement, item)); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Removes the element at the specified index of the collection. | |||
|  |         /// </summary> | |||
|  |         /// <param name="index">The zero-based index of the element to remove.</param> | |||
|  |         protected override void RemoveItem(int index) | |||
|  |         { | |||
|  |             // Remember the removedElement | |||
|  |             ChartNamedElement removedElement = index < Count ? this[index] : null; | |||
|  |             if (_disableDeleteCount == 0) | |||
|  |             { | |||
|  |                 ((INameController)this).OnNameReferenceChanged(new NameReferenceChangedEventArgs(removedElement, null)); | |||
|  |             }             | |||
|  |             base.RemoveItem(index); | |||
|  |             if (_disableDeleteCount == 0) | |||
|  |             { | |||
|  |                 // All elements referencing the removed element will be redirected to the first element in collection | |||
|  |                 // Fire the NameReferenceChanged event to update all the dependent elements | |||
|  |                 ChartNamedElement defaultElement = this.Count > 0 ? this[0] : null; | |||
|  |                 ((INameController)this).OnNameReferenceChanged(new NameReferenceChangedEventArgs(removedElement, defaultElement)); | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Fixes the name references of the item. | |||
|  |         /// </summary> | |||
|  |         internal virtual void FixNameReferences(T item) | |||
|  |         {  | |||
|  |             //Nothing to fix at the base class... | |||
|  |         } | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |         #region INameController Members | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Determines whether is the name us unique. | |||
|  |         /// </summary> | |||
|  |         /// <param name="name">The name.</param> | |||
|  |         /// <returns> | |||
|  |         /// 	<c>true</c> if is the name us unique; otherwise, <c>false</c>. | |||
|  |         /// </returns> | |||
|  |         bool INameController.IsUniqueName(string name) | |||
|  |         { | |||
|  |             return this.IsUniqueName(name); | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets or sets a value indicating whether this instance is in edit mode by collecrtion editor. | |||
|  |         /// </summary> | |||
|  |         /// <value> | |||
|  |         /// 	<c>true</c> if this instance the colection is editing; otherwise, <c>false</c>. | |||
|  |         /// </value> | |||
|  |         bool INameController.IsColectionEditing | |||
|  |         { | |||
|  |             get | |||
|  |             { | |||
|  |                 return _disableDeleteCount == 0; | |||
|  |             } | |||
|  |             set | |||
|  |             { | |||
|  |                 _disableDeleteCount += value ? 1 : -1; | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Raises the <see cref="E:NameReferenceChanging"/> event. | |||
|  |         /// </summary> | |||
|  |         /// <param name="e">The <see cref="NameReferenceChangedEventArgs"/> instance containing the event data.</param> | |||
|  |         void INameController.OnNameReferenceChanging(NameReferenceChangedEventArgs e) | |||
|  |         { | |||
|  |             if (!IsSuspended) | |||
|  |             { | |||
|  |                 if (this.NameReferenceChanging != null) | |||
|  |                     this.NameReferenceChanging(this, e); | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Raises the <see cref="E:NameReferenceChanged"/> event. | |||
|  |         /// </summary> | |||
|  |         /// <param name="e">The <see cref="NameReferenceChangedEventArgs"/> instance containing the event data.</param> | |||
|  |         void INameController.OnNameReferenceChanged(NameReferenceChangedEventArgs e) | |||
|  |         { | |||
|  |             if (!IsSuspended) | |||
|  |             { | |||
|  |                 if (this.NameReferenceChanged != null) | |||
|  |                     this.NameReferenceChanged(this, e); | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Does the snapshot of collection items. | |||
|  |         /// </summary> | |||
|  |         /// <param name="save">if set to <c>true</c> collection items will be saved.</param> | |||
|  |         /// <param name="changingCallback">The changing callback.</param> | |||
|  |         /// <param name="changedCallback">The changed callback.</param> | |||
|  |         void INameController.DoSnapshot(bool save,  | |||
|  |             EventHandler<NameReferenceChangedEventArgs> changingCallback,  | |||
|  |             EventHandler<NameReferenceChangedEventArgs> changedCallback) | |||
|  |         { | |||
|  |             if (save) | |||
|  |             { | |||
|  |                 _cachedState = new List<T>(this); | |||
|  |                 if (changingCallback != null) this.NameReferenceChanging += changingCallback; | |||
|  |                 if (changedCallback  != null) this.NameReferenceChanged += changedCallback; | |||
|  |             } | |||
|  |             else | |||
|  |             { | |||
|  |                 if (changingCallback != null) this.NameReferenceChanging -= changingCallback; | |||
|  |                 if (changedCallback != null) this.NameReferenceChanged -= changedCallback; | |||
|  |                 _cachedState.Clear(); | |||
|  |                 _cachedState = null; | |||
|  |             } | |||
|  |         } | |||
|  | 
 | |||
|  |         /// <summary> | |||
|  |         /// Gets the snapshot of saved collection items. | |||
|  |         /// </summary> | |||
|  |         /// <value>The snapshot.</value> | |||
|  |         IList INameController.Snapshot | |||
|  |         { | |||
|  |             get { return _cachedState; } | |||
|  |         } | |||
|  | 
 | |||
|  | 
 | |||
|  |         #endregion | |||
|  | 
 | |||
|  |          | |||
|  |     } | |||
|  | 
 | |||
|  | } |