Files
Umbraco-CMS/src/Umbraco.Core/Collections/OrderedHashSet.cs
Mole bf41c2eeaa Netcore: Align namespaces (#9801)
* 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
2021-02-18 11:06:02 +01:00

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;
}
}
}