@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMapOf( K2 k1, char v1, K2 k2, char v2, K2 k3, char v3, K2 k4, char v4) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(4); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( Map<? extends K2, Character> map, int expectedSize) { if (map instanceof ObjCharMap) { // noinspection unchecked ObjCharMap<K2> objCharMap = (ObjCharMap<K2>) map; if (map instanceof SeparateKVObjCharLHash) { SeparateKVObjCharLHash hash = (SeparateKVObjCharLHash) map; if (hash.hashConfig().equals(hashConf) && objCharMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableLHashSeparateKVObjCharMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableLHashSeparateKVObjCharMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableLHashSeparateKVObjCharMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Character> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMapOf( K2 k1, char v1, K2 k2, char v2, K2 k3, char v3, K2 k4, char v4) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(4); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( Map<? extends K2, Character> map, int expectedSize) { if (map instanceof ObjCharMap) { // noinspection unchecked ObjCharMap<K2> objCharMap = (ObjCharMap<K2>) map; if (map instanceof SeparateKVObjCharLHash) { SeparateKVObjCharLHash hash = (SeparateKVObjCharLHash) map; if (hash.hashConfig().equals(hashConf) && objCharMap.keyEquivalence().equals(getKeyEquivalence())) { UpdatableLHashSeparateKVObjCharMapGO<K2> res = uninitializedUpdatableMap(); res.copy(hash); return res; } } UpdatableLHashSeparateKVObjCharMapGO<K2> res = newUpdatableMap(expectedSize); res.putAll(map); return res; } else { UpdatableLHashSeparateKVObjCharMapGO<K2> res = newUpdatableMap(expectedSize); for (Map.Entry<? extends K2, Character> entry : map.entrySet()) { res.put(entry.getKey(), entry.getValue()); } return res; } } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMapOf( K2 k1, char v1, K2 k2, char v2, K2 k3, char v3, K2 k4, char v4, K2 k5, char v5) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(5); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); map.put(k5, v5); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMapOf( K2 k1, char v1, K2 k2, char v2, K2 k3, char v3, K2 k4, char v4, K2 k5, char v5) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(5); map.put(k1, v1); map.put(k2, v2); map.put(k3, v3); map.put(k4, v4); map.put(k5, v5); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMapOf( K2 k1, char v1) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(1); map.put(k1, v1); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMapOf( K2 k1, char v1) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(1); map.put(k1, v1); return map; }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( K2[] keys, Character[] values, int expectedSize) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( K2[] keys, char[] values, int expectedSize) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( K2[] keys, char[] values, int expectedSize) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( K2[] keys, Character[] values, int expectedSize) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(expectedSize); int keysLen = keys.length; if (keysLen != values.length) throw new IllegalArgumentException("keys and values arrays must have the same size"); for (int i = 0; i < keys.length; i++) { map.put(keys[i], values[i]); } return shrunk(map); }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( Iterable<? extends K2> keys, Iterable<Character> values, int expectedSize) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(expectedSize); Iterator<? extends K2> keysIt = keys.iterator(); Iterator<Character> valuesIt = values.iterator(); try { while (keysIt.hasNext()) { map.put(keysIt.next(), valuesIt.next()); } return shrunk(map); } catch (NoSuchElementException e) { throw new IllegalArgumentException( "keys and values iterables must have the same size", e); } }
@Override @Nonnull public <K2 extends K> UpdatableLHashSeparateKVObjCharMapGO<K2> newUpdatableMap( Iterable<? extends K2> keys, Iterable<Character> values, int expectedSize) { UpdatableLHashSeparateKVObjCharMapGO<K2> map = newUpdatableMap(expectedSize); Iterator<? extends K2> keysIt = keys.iterator(); Iterator<Character> valuesIt = values.iterator(); try { while (keysIt.hasNext()) { map.put(keysIt.next(), valuesIt.next()); } return shrunk(map); } catch (NoSuchElementException e) { throw new IllegalArgumentException( "keys and values iterables must have the same size", e); } }