ObjLongMap m2 = (ObjLongMap) another; if ( m2.keyEquivalence().equals(map.keyEquivalence()) if (map.size() < m2.size()) return false; if (m2 instanceof InternalObjLongMapOps) { return m2.forEachWhile(new ObjLongPredicate() { @Override
public static <K> void putAll(final InternalObjLongMapOps<K> map, Map<? extends K, ? extends Long> another) { if (map == another) throw new IllegalArgumentException(); long maxPossibleSize = map.sizeAsLong() + Containers.sizeAsLong(another); map.ensureCapacity(maxPossibleSize); if (another instanceof ObjLongMap) { if (another instanceof InternalObjLongMapOps) { ((InternalObjLongMapOps) another).reversePutAllTo(map); } else { ((ObjLongMap) another).forEach(new ObjLongConsumer<K>() { @Override public void accept(K key, long value) { map.justPut(key, value); } }); } } else { for (Map.Entry<? extends K, ? extends Long> e : another.entrySet()) { map.justPut(e.getKey(), e.getValue()); } } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjLongMapGO<K2> newUpdatableMap( Map<? extends K2, Long> map, int expectedSize) { if (map instanceof ObjLongMap) { @SuppressWarnings("unchecked") ObjLongMap<K2> objLongMap = (ObjLongMap<K2>) map; if (map instanceof SeparateKVObjLongLHash) { SeparateKVObjLongLHash hash = (SeparateKVObjLongLHash) map; if (hash.hashConfig().equals(hashConf) && objLongMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableLHashSeparateKVObjLongMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableLHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableLHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Long> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
@Override @Nonnull public <K2 extends K> UpdatableQHashSeparateKVObjLongMapGO<K2> newUpdatableMap( Map<? extends K2, Long> map, int expectedSize) { if (map instanceof ObjLongMap) { @SuppressWarnings("unchecked") ObjLongMap<K2> objLongMap = (ObjLongMap<K2>) map; if (map instanceof SeparateKVObjLongQHash) { SeparateKVObjLongQHash hash = (SeparateKVObjLongQHash) map; if (hash.hashConfig().equals(hashConf) && objLongMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableQHashSeparateKVObjLongMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableQHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableQHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Long> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
ObjLongMap m2 = (ObjLongMap) another; if ( m2.keyEquivalence().equals(map.keyEquivalence()) if (map.size() < m2.size()) return false; if (m2 instanceof InternalObjLongMapOps) { return m2.forEachWhile(new ObjLongPredicate() { @Override
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjLongMapGO<K2> newUpdatableMap( Map<? extends K2, Long> map, int expectedSize) { if (map instanceof ObjLongMap) { @SuppressWarnings("unchecked") ObjLongMap<K2> objLongMap = (ObjLongMap<K2>) map; if (map instanceof SeparateKVObjLongLHash) { SeparateKVObjLongLHash hash = (SeparateKVObjLongLHash) map; if (hash.hashConfig().equals(hashConf) && objLongMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableLHashSeparateKVObjLongMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableLHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableLHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Long> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
public static <K> void putAll(final InternalObjLongMapOps<K> map, Map<? extends K, ? extends Long> another) { if (map == another) throw new IllegalArgumentException(); long maxPossibleSize = map.sizeAsLong() + Containers.sizeAsLong(another); map.ensureCapacity(maxPossibleSize); if (another instanceof ObjLongMap) { if (another instanceof InternalObjLongMapOps) { ((InternalObjLongMapOps) another).reversePutAllTo(map); } else { ((ObjLongMap) another).forEach(new ObjLongConsumer<K>() { @Override public void accept(K key, long value) { map.justPut(key, value); } }); } } else { for (Map.Entry<? extends K, ? extends Long> e : another.entrySet()) { map.justPut(e.getKey(), e.getValue()); } } }
@Override @Nonnull public <K2 extends K> UpdatableQHashSeparateKVObjLongMapGO<K2> newUpdatableMap( Map<? extends K2, Long> map, int expectedSize) { if (map instanceof ObjLongMap) { @SuppressWarnings("unchecked") ObjLongMap<K2> objLongMap = (ObjLongMap<K2>) map; if (map instanceof SeparateKVObjLongQHash) { SeparateKVObjLongQHash hash = (SeparateKVObjLongQHash) map; if (hash.hashConfig().equals(hashConf) && objLongMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableQHashSeparateKVObjLongMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableQHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableQHashSeparateKVObjLongMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Long> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }