The debugger visualizers used by .NET clustered classes are internal. Which makes them a little difficult to use, you cannot use typeof (). There is a backdoor there, and the [DebuggerTypeProxy] attribute also has a constructor that takes a string. The one you want to use is called Mscorlib_CollectionDebugView, it is able to render any class that implements ICollection <>. Here is a usage example:
[DebuggerTypeProxy("System.Collections.Generic.Mscorlib_CollectionDebugView`1, mscorlib, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089")]
class MyCollection<T> : IList<T> {
private List<T> impl = new List<T>();
public int IndexOf(T item) { return impl.IndexOf(item); }
public void Insert(int index, T item) { impl.Insert(index, item); }
public void RemoveAt(int index) { impl.RemoveAt(index); }
public T this[int index] {
get { return impl[index]; }
set { impl[index] = value; }
}
public void Add(T item) { impl.Add(item); }
public void Clear() { impl.Clear(); }
public bool Contains(T item) { return impl.Contains(item); }
public void CopyTo(T[] array, int arrayIndex) { impl.CopyTo(array, arrayIndex); }
public int Count { get { return impl.Count; }}
public bool IsReadOnly { get { return ((System.Collections.IList)impl).IsReadOnly; }}
public bool Remove(T item) { return impl.Remove(item); }
public IEnumerator<T> GetEnumerator() { return impl.GetEnumerator(); }
System.Collections.IEnumerator System.Collections.IEnumerable.GetEnumerator() { return GetEnumerator(); }
}
This also works for .NET 4.0, although the version number is incorrect. This otherwise runs the risk of hacking with the next version of .NET if they decide to rename the inner class.
source
share