All the controls missing in WPF. Over 1 million downloads.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

94 lines
2.6 KiB

/*************************************************************************************
Extended WPF Toolkit
Copyright (C) 2007-2013 Xceed Software Inc.
This program is provided to you under the terms of the Microsoft Public
License (Ms-PL) as published at http://wpftoolkit.codeplex.com/license
For more features, controls, and fast professional support,
pick up the Plus Edition at http://xceed.com/wpf_toolkit
Stay informed: follow @datagrid on Twitter or Like http://facebook.com/datagrids
***********************************************************************************/
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Xceed.Wpf.AvalonDock.Controls
{
class WeakDictionary<K,V> where K : class
{
public WeakDictionary()
{}
List<WeakReference> _keys = new List<WeakReference>();
List<V> _values = new List<V>();
public V this[K key]
{
get
{
V valueToReturn;
if (!GetValue(key, out valueToReturn))
throw new ArgumentException();
return valueToReturn;
}
set
{
SetValue(key, value);
}
}
public bool ContainsKey(K key)
{
CollectGarbage();
return -1 != _keys.FindIndex(k => k.GetValueOrDefault<K>() == key);
}
public void SetValue(K key, V value)
{
CollectGarbage();
int vIndex = _keys.FindIndex(k => k.GetValueOrDefault<K>() == key);
if (vIndex > -1)
_values[vIndex] = value;
else
{
_values.Add(value);
_keys.Add(new WeakReference(key));
}
}
public bool GetValue(K key, out V value)
{
CollectGarbage();
int vIndex = _keys.FindIndex(k => k.GetValueOrDefault<K>() == key);
value = default(V);
if (vIndex == -1)
return false;
value = _values[vIndex];
return true;
}
void CollectGarbage()
{
int vIndex = 0;
do
{
vIndex = _keys.FindIndex(vIndex, k => !k.IsAlive);
if (vIndex >= 0)
{
_keys.RemoveAt(vIndex);
_values.RemoveAt(vIndex);
}
}
while (vIndex >= 0);
}
}
}