* Rename Umbraco.Core namespace to Umbraco.Cms.Core * Move extension methods in core project to Umbraco.Extensions * Move extension methods in core project to Umbraco.Extensions * Rename Umbraco.Examine namespace to Umbraco.Cms.Examine * Move examine extensions to Umbraco.Extensions namespace * Reflect changed namespaces in Builder and fix unit tests * Adjust namespace in Umbraco.ModelsBuilder.Embedded * Adjust namespace in Umbraco.Persistence.SqlCe * Adjust namespace in Umbraco.PublishedCache.NuCache * Align namespaces in Umbraco.Web.BackOffice * Align namespaces in Umbraco.Web.Common * Ensure that SqlCeSupport is still enabled after changing the namespace * Align namespaces in Umbraco.Web.Website * Align namespaces in Umbraco.Web.UI.NetCore * Align namespaces in Umbraco.Tests.Common * Align namespaces in Umbraco.Tests.UnitTests * Align namespaces in Umbraco.Tests.Integration * Fix errors caused by changed namespaces * Fix integration tests * Undo the Umbraco.Examine.Lucene namespace change This breaks integration tests on linux, since the namespace wont exists there because it's only used on windows. * Fix merge * Fix Merge
51 lines
1.4 KiB
C#
51 lines
1.4 KiB
C#
using System.Collections.ObjectModel;
|
|
|
|
namespace Umbraco.Cms.Core.Collections
|
|
{
|
|
/// <summary>
|
|
/// A custom collection similar to HashSet{T} which only contains unique items, however this collection keeps items in order
|
|
/// and is customizable to keep the newest or oldest equatable item
|
|
/// </summary>
|
|
/// <typeparam name="T"></typeparam>
|
|
public class OrderedHashSet<T> : KeyedCollection<T, T>
|
|
{
|
|
private readonly bool _keepOldest;
|
|
|
|
public OrderedHashSet(bool keepOldest = true)
|
|
{
|
|
_keepOldest = keepOldest;
|
|
}
|
|
|
|
protected override void InsertItem(int index, T item)
|
|
{
|
|
if (Dictionary == null)
|
|
{
|
|
base.InsertItem(index, item);
|
|
}
|
|
else
|
|
{
|
|
var exists = Dictionary.ContainsKey(item);
|
|
|
|
//if we want to keep the newest, then we need to remove the old item and add the new one
|
|
if (exists == false)
|
|
{
|
|
base.InsertItem(index, item);
|
|
}
|
|
else if(_keepOldest == false)
|
|
{
|
|
if (Remove(item))
|
|
{
|
|
index--;
|
|
}
|
|
base.InsertItem(index, item);
|
|
}
|
|
}
|
|
}
|
|
|
|
protected override T GetKeyForItem(T item)
|
|
{
|
|
return item;
|
|
}
|
|
}
|
|
}
|