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
 | ||
| 
 | ||
|         
 | ||
|     }
 | ||
| 
 | ||
| }
 |