com.koloboke.collect.impl.CommonShortObjMapOps Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of koloboke-impl-common-jdk8 Show documentation
Show all versions of koloboke-impl-common-jdk8 Show documentation
Carefully designed and efficient extension of the Java Collections Framework with primitive specializations and more, built for Java 8 (Implementation Commons (for Implementation Library and Koloboke Compile))
The newest version!
/*
* Copyright 2014 the original author or authors.
*
* 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.
*/
package com.koloboke.collect.impl;
import com.koloboke.function.ShortObjPredicate;
import com.koloboke.function.ShortObjConsumer;
import com.koloboke.collect.map.ShortObjMap;
import java.util.Map;
public final class CommonShortObjMapOps {
public static boolean containsAllEntries(final InternalShortObjMapOps> map,
Map, ?> another) {
if (map == another)
throw new IllegalArgumentException();
if (another instanceof ShortObjMap) {
ShortObjMap m2 = (ShortObjMap) another;
if (
m2.valueEquivalence().equals(map.valueEquivalence())
) {
if (map.size() < m2.size())
return false;
if (m2 instanceof InternalShortObjMapOps) {
//noinspection unchecked
return ((InternalShortObjMapOps) m2).allEntriesContainingIn(map);
}
}
// noinspection unchecked
return m2.forEachWhile(new
ShortObjPredicate() {
@Override
public boolean test(short a, Object b) {
return map.containsEntry(a, b);
}
});
}
for (Map.Entry, ?> e : another.entrySet()) {
if (!map.containsEntry((Short) e.getKey(),
e.getValue()))
return false;
}
return true;
}
public static void putAll(final InternalShortObjMapOps map,
Map extends Short, ? extends V> another) {
if (map == another)
throw new IllegalArgumentException();
long maxPossibleSize = map.sizeAsLong() + Containers.sizeAsLong(another);
map.ensureCapacity(maxPossibleSize);
if (another instanceof ShortObjMap) {
if (another instanceof InternalShortObjMapOps) {
((InternalShortObjMapOps) another).reversePutAllTo(map);
} else {
((ShortObjMap) another).forEach(new ShortObjConsumer() {
@Override
public void accept(short key, V value) {
map.justPut(key, value);
}
});
}
} else {
for (Map.Entry extends Short, ? extends V> e : another.entrySet()) {
map.justPut(e.getKey(), e.getValue());
}
}
}
private CommonShortObjMapOps() {}
}