com.cedarsoftware.util.CaseInsensitiveSet Maven / Gradle / Ivy
package com.cedarsoftware.util;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.Map;
import java.util.Set;
import java.util.SortedSet;
import java.util.TreeMap;
import java.util.concurrent.ConcurrentSkipListMap;
import java.util.concurrent.ConcurrentSkipListSet;
/**
* Implements a java.util.Set that will not utilize 'case' when comparing Strings
* contained within the Set. The set can be homogeneous or heterogeneous.
* If the CaseInsensitiveSet is iterated, when Strings are encountered, the original
* Strings are returned (retains case).
*
* @author John DeRegnaucourt ([email protected])
*
* Copyright (c) Cedar Software LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
public class CaseInsensitiveSet implements Set
{
private final Map map;
public CaseInsensitiveSet() { map = new CaseInsensitiveMap<>(); }
public CaseInsensitiveSet(Collection extends E> collection)
{
if (collection instanceof ConcurrentSkipListSet)
{
map = new CaseInsensitiveMap<>(new ConcurrentSkipListMap());
}
else if (collection instanceof SortedSet)
{
map = new CaseInsensitiveMap<>(new TreeMap());
}
else
{
map = new CaseInsensitiveMap<>(collection.size());
}
addAll(collection);
}
public CaseInsensitiveSet(int initialCapacity)
{
map = new CaseInsensitiveMap<>(initialCapacity);
}
public CaseInsensitiveSet(int initialCapacity, float loadFactor)
{
map = new CaseInsensitiveMap<>(initialCapacity, loadFactor);
}
public int hashCode()
{
int hash = 0;
for (Object item : map.keySet())
{
if (item != null)
{
if (item instanceof String)
{
hash += ((String)item).toLowerCase().hashCode();
}
else
{
hash += item.hashCode();
}
}
}
return hash;
}
public boolean equals(Object other)
{
if (other == this) return true;
if (!(other instanceof Set)) return false;
Set that = (Set) other;
return that.size()==size() && containsAll(that);
}
public int size()
{
return map.size();
}
public boolean isEmpty()
{
return map.isEmpty();
}
public boolean contains(Object o)
{
return map.containsKey(o);
}
public Iterator iterator()
{
return map.keySet().iterator();
}
public Object[] toArray()
{
return map.keySet().toArray();
}
public T[] toArray(T[] a)
{
return map.keySet().toArray(a);
}
public boolean add(E e)
{
boolean exists = map.containsKey(e);
map.put(e, e);
return !exists;
}
public boolean remove(Object o)
{
boolean exists = map.containsKey(o);
map.remove(o);
return exists;
}
public boolean containsAll(Collection> c)
{
for (Object o : c)
{
if (!map.containsKey(o))
{
return false;
}
}
return true;
}
public boolean addAll(Collection extends E> c)
{
int size = size();
for (E elem : c)
{
map.put(elem, elem);
}
return map.size() != size;
}
public boolean retainAll(Collection> c)
{
Map other = new CaseInsensitiveMap();
for (Object o : c)
{
other.put(o, null);
}
Iterator i = map.keySet().iterator();
int size = size();
while (i.hasNext())
{
Object elem = i.next();
if (!other.containsKey(elem))
{
i.remove();
}
}
return map.size() != size;
}
public boolean removeAll(Collection> c)
{
int size = size();
for (Object elem : c)
{
map.remove(elem);
}
return map.size() != size;
}
public void clear()
{
map.clear();
}
public String toString()
{
return map.keySet().toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy