|
|
|
using System.Collections;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Collections.ObjectModel;
|
|
|
|
|
|
|
|
namespace SharpCifs.Util.Sharpen
|
|
|
|
{
|
|
|
|
internal static class Collections<T>
|
|
|
|
{
|
|
|
|
static readonly IList<T> Empty = new T[0];
|
|
|
|
public static IList<T> EmptySet
|
|
|
|
{
|
|
|
|
get { return Empty; }
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class Collections
|
|
|
|
{
|
|
|
|
public static bool AddAll<T>(ICollection<T> list, IEnumerable toAdd)
|
|
|
|
{
|
|
|
|
foreach (T t in toAdd)
|
|
|
|
list.Add(t);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static TV Remove<TK, TV>(IDictionary<TK, TV> map, TK toRemove) where TK : class
|
|
|
|
{
|
|
|
|
TV local;
|
|
|
|
if (map.TryGetValue(toRemove, out local))
|
|
|
|
{
|
|
|
|
map.Remove(toRemove);
|
|
|
|
return local;
|
|
|
|
}
|
|
|
|
return default(TV);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static T[] ToArray<T>(ICollection<T> list)
|
|
|
|
{
|
|
|
|
T[] array = new T[list.Count];
|
|
|
|
list.CopyTo(array, 0);
|
|
|
|
return array;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static T[] ToArray<T>(List<object> list)
|
|
|
|
{
|
|
|
|
T[] array = new T[list.Count];
|
|
|
|
for (int c = 0; c < list.Count; c++)
|
|
|
|
{
|
|
|
|
array[c] = (T)list[c];
|
|
|
|
}
|
|
|
|
|
|
|
|
return array;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public static TU[] ToArray<T, TU>(ICollection<T> list, TU[] res) where T : TU
|
|
|
|
{
|
|
|
|
if (res.Length < list.Count)
|
|
|
|
res = new TU[list.Count];
|
|
|
|
|
|
|
|
int n = 0;
|
|
|
|
foreach (T t in list)
|
|
|
|
res[n++] = t;
|
|
|
|
|
|
|
|
if (res.Length > list.Count)
|
|
|
|
res[list.Count] = default(T);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IDictionary<TK, TV> EmptyMap<TK, TV>()
|
|
|
|
{
|
|
|
|
return new Dictionary<TK, TV>();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IList<T> EmptyList<T>()
|
|
|
|
{
|
|
|
|
return Collections<T>.EmptySet;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static ICollection<T> EmptySet<T>()
|
|
|
|
{
|
|
|
|
return Collections<T>.EmptySet;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IList<T> NCopies<T>(int n, T elem)
|
|
|
|
{
|
|
|
|
List<T> list = new List<T>(n);
|
|
|
|
while (n-- > 0)
|
|
|
|
{
|
|
|
|
list.Add(elem);
|
|
|
|
}
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void Reverse<T>(IList<T> list)
|
|
|
|
{
|
|
|
|
int end = list.Count - 1;
|
|
|
|
int index = 0;
|
|
|
|
while (index < end)
|
|
|
|
{
|
|
|
|
T tmp = list[index];
|
|
|
|
list[index] = list[end];
|
|
|
|
list[end] = tmp;
|
|
|
|
++index;
|
|
|
|
--end;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static ICollection<T> Singleton<T>(T item)
|
|
|
|
{
|
|
|
|
List<T> list = new List<T>(1);
|
|
|
|
list.Add(item);
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IList<T> SingletonList<T>(T item)
|
|
|
|
{
|
|
|
|
List<T> list = new List<T>(1);
|
|
|
|
list.Add(item);
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IList<T> SynchronizedList<T>(IList<T> list)
|
|
|
|
{
|
|
|
|
return new SynchronizedList<T>(list);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static ICollection<T> UnmodifiableCollection<T>(ICollection<T> list)
|
|
|
|
{
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IList<T> UnmodifiableList<T>(IList<T> list)
|
|
|
|
{
|
|
|
|
return new ReadOnlyCollection<T>(list);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static ICollection<T> UnmodifiableSet<T>(ICollection<T> list)
|
|
|
|
{
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static IDictionary<TK, TV> UnmodifiableMap<TK, TV>(IDictionary<TK, TV> dict)
|
|
|
|
{
|
|
|
|
return dict;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|