Merge remote-tracking branch 'origin/main' into 1.18
This commit is contained in:
commit
1335a892b1
|
|
@ -137,11 +137,14 @@ public class CanonizingStringMap<T> implements Map<String, T> {
|
||||||
|
|
||||||
public static <T> CanonizingStringMap<T> deepCopy(CanonizingStringMap<T> inputMap, Function<T, T> deepCopier) {
|
public static <T> CanonizingStringMap<T> deepCopy(CanonizingStringMap<T> inputMap, Function<T, T> deepCopier) {
|
||||||
Object2ObjectMap<String, T> copiedBackingMap;
|
Object2ObjectMap<String, T> copiedBackingMap;
|
||||||
if(inputMap.backingMap instanceof Object2ObjectArrayMap)
|
int size = inputMap.backingMap.size();
|
||||||
copiedBackingMap = ((Object2ObjectArrayMap<String, T>)inputMap.backingMap).clone();
|
if(size > GROWTH_THRESHOLD) {
|
||||||
else
|
copiedBackingMap = new Object2ObjectOpenHashMap<>(size);
|
||||||
copiedBackingMap = ((Object2ObjectOpenHashMap<String, T>)inputMap.backingMap).clone();
|
} else
|
||||||
copiedBackingMap.replaceAll((k, v) -> deepCopier.apply(v));
|
copiedBackingMap = new Object2ObjectArrayMap<>(size);
|
||||||
|
inputMap.backingMap.object2ObjectEntrySet().forEach(entry -> {
|
||||||
|
copiedBackingMap.put(entry.getKey(), deepCopier.apply(entry.getValue()));
|
||||||
|
});
|
||||||
return new CanonizingStringMap<>(copiedBackingMap);
|
return new CanonizingStringMap<>(copiedBackingMap);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user