PageRenderTime 57ms CodeModel.GetById 32ms RepoModel.GetById 1ms app.codeStats 0ms

/source/library/Interlace/Collections/TrackedBindingList.cs

https://bitbucket.org/VahidN/interlace
C# | 100 lines | 53 code | 16 blank | 31 comment | 6 complexity | ff874479e19b516a37055904b50e6285 MD5 | raw file
  1. #region Using Directives and Copyright Notice
  2. // Copyright (c) 2007-2010, Computer Consultancy Pty Ltd
  3. // All rights reserved.
  4. //
  5. // Redistribution and use in source and binary forms, with or without
  6. // modification, are permitted provided that the following conditions are met:
  7. // * Redistributions of source code must retain the above copyright
  8. // notice, this list of conditions and the following disclaimer.
  9. // * Redistributions in binary form must reproduce the above copyright
  10. // notice, this list of conditions and the following disclaimer in the
  11. // documentation and/or other materials provided with the distribution.
  12. // * Neither the name of the Computer Consultancy Pty Ltd nor the
  13. // names of its contributors may be used to endorse or promote products
  14. // derived from this software without specific prior written permission.
  15. //
  16. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  17. // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  18. // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  19. // ARE DISCLAIMED. IN NO EVENT SHALL COMPUTER CONSULTANCY PTY LTD BE LIABLE
  20. // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  21. // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  22. // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  23. // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  24. // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  25. // OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH
  26. // DAMAGE.
  27. using System;
  28. using System.Collections.Generic;
  29. using System.ComponentModel;
  30. using System.Text;
  31. #endregion
  32. namespace Interlace.Collections
  33. {
  34. /// <summary>
  35. /// A binding list that guarantees a call to an event any time an item is added and removed from a list.
  36. /// </summary>
  37. /// <typeparam name="T">The type of item in the list.</typeparam>
  38. /// <remarks>The guarantee is based on the reflected source code; in the current version of the framework,
  39. /// nothing other than the overridable methods of Collection&lt;T&gt; modifies the list.</remarks>
  40. public class TrackedBindingList<T> : BindingList<T>
  41. {
  42. public event EventHandler<TrackedBindingListEventArgs<T>> Added;
  43. public event EventHandler<TrackedBindingListEventArgs<T>> Removed;
  44. protected virtual void OnAdded(T item)
  45. {
  46. if (Added != null) Added(this, new TrackedBindingListEventArgs<T>(item));
  47. }
  48. protected virtual void OnRemoved(T item)
  49. {
  50. if (Removed != null) Removed(this, new TrackedBindingListEventArgs<T>(item));
  51. }
  52. protected override void ClearItems()
  53. {
  54. foreach (T item in Items)
  55. {
  56. OnRemoved(item);
  57. }
  58. base.ClearItems();
  59. }
  60. protected override void InsertItem(int index, T item)
  61. {
  62. base.InsertItem(index, item);
  63. OnAdded(item);
  64. }
  65. protected override void RemoveItem(int index)
  66. {
  67. OnRemoved(Items[index]);
  68. base.RemoveItem(index);
  69. }
  70. protected override void SetItem(int index, T item)
  71. {
  72. T existingItem = Items[index];
  73. if (!object.ReferenceEquals(item, existingItem))
  74. {
  75. OnRemoved(existingItem);
  76. }
  77. base.SetItem(index, item);
  78. if (!object.ReferenceEquals(item, existingItem))
  79. {
  80. OnAdded(item);
  81. }
  82. }
  83. }
  84. }