net.anwiba.commons.lang.hashable.HashableMap Maven / Gradle / Ivy
/*
* #%L
* anwiba commons core
* %%
* Copyright (C) 2007 - 2016 Andreas Bartels
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 2.1 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
package net.anwiba.commons.lang.hashable;
import java.io.Serializable;
import java.util.Collection;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
public final class HashableMap implements Map, Serializable, Cloneable {
private static final long serialVersionUID = -3641759535670670188L;
final HashMap, V> map;
public HashableMap() {
this.map = new HashMap<>();
}
public HashableMap(final int initialCapacity) {
this.map = new HashMap<>(initialCapacity);
}
public HashableMap(final int initialCapacity, final float loadFactor) {
this.map = new HashMap<>(initialCapacity, loadFactor);
}
HashableMap(final HashMap, V> map) {
this.map = map;
}
@Override
public int size() {
return this.map.size();
}
@Override
public boolean isEmpty() {
return this.map.isEmpty();
}
@Override
public V put(final K key, final V value) {
return this.map.put(new HashableWrapper<>(key), value);
}
@Override
public boolean containsValue(final Object value) {
return this.map.containsValue(value);
}
@Override
public boolean containsKey(final Object key) {
if (key != null && !(key instanceof IHashable)) {
return false;
}
final IHashable hashable = (IHashable) key;
return this.map.containsKey(new HashableWrapper<>(hashable));
}
@Override
public V get(final Object key) {
if (key != null && !(key instanceof IHashable)) {
return null;
}
final IHashable hashable = (IHashable) key;
return this.map.get(new HashableWrapper<>(hashable));
}
@Override
public V remove(final Object key) {
if (key != null && !(key instanceof IHashable)) {
return null;
}
final IHashable hashable = (IHashable) key;
return this.map.remove(new HashableWrapper<>(hashable));
}
@Override
public void putAll(@SuppressWarnings("hiding") final Map extends K, ? extends V> map) {
final int numKeysToBeAdded = map.size();
if (numKeysToBeAdded == 0) {
return;
}
final HashMap, V> tmp = new HashMap<>(map.size());
for (final Iterator extends Map.Entry extends K, ? extends V>> i = map.entrySet().iterator(); i.hasNext();) {
final Map.Entry extends K, ? extends V> e = i.next();
tmp.put(new HashableWrapper(e.getKey()), e.getValue());
}
this.map.putAll(tmp);
}
@Override
public void clear() {
this.map.clear();
}
@SuppressWarnings({ "rawtypes", "unchecked" })
@Override
public Set keySet() {
final Set> keySet = this.map.keySet();
if (keySet instanceof HashSet) {
final HashableSet hashableSet = new HashableSet<>();
hashableSet.addAll((HashSet) this.map.keySet());
return hashableSet;
}
return new HashableSet<>(new HashSet<>(this.map.keySet()));
}
@Override
public Collection values() {
return this.map.values();
}
@Override
public Set> entrySet() {
final Set, V>> wrappedEntrySet = this.map.entrySet();
if (wrappedEntrySet instanceof HashSet) {
return new HashableEntrySet<>((HashSet, V>>) wrappedEntrySet);
}
return new HashableEntrySet<>(new HashSet<>(wrappedEntrySet));
}
@Override
public int hashCode() {
return this.map.hashCode();
}
@SuppressWarnings("unchecked")
@Override
public boolean equals(final Object object) {
if (object == this) {
return true;
}
if (!(object instanceof Map)) {
return false;
}
final Map other = (Map) object;
if (other.size() != size()) {
return false;
}
try {
for (final Entry entry : entrySet()) {
final K key = entry.getKey();
final V value = entry.getValue();
if (value == null) {
if (!(other.get(key) == null && other.containsKey(key))) {
return false;
}
continue;
}
if (!value.equals(other.get(key))) {
return false;
}
}
} catch (final ClassCastException unused) {
return false;
} catch (final NullPointerException unused) {
return false;
}
return true;
}
@SuppressWarnings("unchecked")
@Override
public HashableMap clone() {
return new HashableMap<>((HashMap, V>) this.map.clone());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy