View of /trunk/DoubleDictionary.cs
Parent Directory
|
Revision Log
Revision 24 -
(download)
(annotate)
Fri Nov 14 21:10:28 2008 UTC (4 years, 6 months ago) by jhurliman
File size: 4348 byte(s)
Fri Nov 14 21:10:28 2008 UTC (4 years, 6 months ago) by jhurliman
File size: 4348 byte(s)
* Replaced the three storage interfaces with IStorageProvider * Storage requests return StorageResponse enum instead of a bool * Added authentication and authorization interfaces * Added OpenID authentication provider, only the browser-based interface at /authenticate right now * All storage providers now receive an authToken for each action and check with the authorization provider * Fixed Authorization: header parsing * Added a dummy AuthorizeAll authorization provider * Added TryFetchDataMetadata(), an optimized path for some storage providers * ForEach() now takes a required start position and count * Added pagination to BrowseInterface * Removed DistributedStorage, going to take a new optimization route * Updated to latest ExtensionLoader
using System;
using System.Collections.Generic;
namespace AssetServer
{
public class DoubleDictionary<TKey1, TKey2, TValue>
{
Dictionary<TKey1, TValue> Dictionary1;
Dictionary<TKey2, TValue> Dictionary2;
object syncObject = new object();
public DoubleDictionary()
{
Dictionary1 = new Dictionary<TKey1,TValue>();
Dictionary2 = new Dictionary<TKey2,TValue>();
}
public DoubleDictionary(int capacity)
{
Dictionary1 = new Dictionary<TKey1, TValue>(capacity);
Dictionary2 = new Dictionary<TKey2, TValue>(capacity);
}
public void Add(TKey1 key1, TKey2 key2, TValue value)
{
lock (syncObject)
{
if (Dictionary1.ContainsKey(key1))
{
if (!Dictionary2.ContainsKey(key2))
throw new ArgumentException("key1 exists in the dictionary but not key2");
}
else if (Dictionary2.ContainsKey(key2))
{
if (!Dictionary1.ContainsKey(key1))
throw new ArgumentException("key2 exists in the dictionary but not key1");
}
Dictionary1[key1] = value;
Dictionary2[key2] = value;
}
}
public bool Remove(TKey1 key1, TKey2 key2)
{
lock (syncObject)
{
Dictionary1.Remove(key1);
return Dictionary2.Remove(key2);
}
}
public bool Remove(TKey1 key1)
{
// This is an O(n) operation!
lock (syncObject)
{
TValue value;
if (Dictionary1.TryGetValue(key1, out value))
{
foreach (KeyValuePair<TKey2, TValue> kvp in Dictionary2)
{
if (kvp.Value.Equals(value))
{
Dictionary1.Remove(key1);
Dictionary2.Remove(kvp.Key);
return true;
}
}
}
}
return false;
}
public bool Remove(TKey2 key2)
{
// This is an O(n) operation!
lock (syncObject)
{
TValue value;
if (Dictionary2.TryGetValue(key2, out value))
{
foreach (KeyValuePair<TKey1, TValue> kvp in Dictionary1)
{
if (kvp.Value.Equals(value))
{
Dictionary2.Remove(key2);
Dictionary1.Remove(kvp.Key);
return true;
}
}
}
}
return false;
}
public void Clear()
{
lock (syncObject)
{
Dictionary1.Clear();
Dictionary2.Clear();
}
}
public int Count
{
get { return Dictionary1.Count; }
}
public bool ContainsKey(TKey1 key)
{
return Dictionary1.ContainsKey(key);
}
public bool ContainsKey(TKey2 key)
{
return Dictionary2.ContainsKey(key);
}
public bool TryGetValue(TKey1 key, out TValue value)
{
return Dictionary1.TryGetValue(key, out value);
}
public bool TryGetValue(TKey2 key, out TValue value)
{
return Dictionary2.TryGetValue(key, out value);
}
public void ForEach(Action<TValue> action)
{
lock (syncObject)
{
foreach (TValue value in Dictionary1.Values)
action(value);
}
}
public TValue this[TKey1 key1]
{
get { return Dictionary1[key1]; }
}
public TValue this[TKey2 key2]
{
get { return Dictionary2[key2]; }
}
}
}
| ViewVC Help | |
| Powered by ViewVC 1.0.0 |

