From a61950b5648f6ca9d5e47f96874ff73b9f6129a4 Mon Sep 17 00:00:00 2001 From: Mark Hansen Date: Tue, 19 Nov 2024 10:16:01 +1100 Subject: [PATCH] OpenHashMap.mergeX: Avoid double-hashing key Towards #336 --- drv/OpenHashMap.drv | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/drv/OpenHashMap.drv b/drv/OpenHashMap.drv index 3d3de447..b214a045 100644 --- a/drv/OpenHashMap.drv +++ b/drv/OpenHashMap.drv @@ -36,6 +36,7 @@ import VALUE_PACKAGE.VALUE_COLLECTION; import VALUE_PACKAGE.VALUE_ABSTRACT_COLLECTION; #if VALUES_PRIMITIVE +import VALUE_PACKAGE.VALUE_BINARY_OPERATOR; import VALUE_PACKAGE.VALUE_ITERATOR; import VALUE_PACKAGE.VALUE_SPLITERATOR; import VALUE_PACKAGE.VALUE_SPLITERATORS; @@ -1253,6 +1254,25 @@ public class OPEN_HASH_MAP KEY_VALUE_GENERIC extends ABSTRACT_MAP KEY_VALUE_GENE return value[pos] = newVal; } +#if VALUES_PRIMITIVE && ! VALUE_CLASS_Boolean + /** {@inheritDoc} */ + @Override + public VALUE_GENERIC_TYPE MERGE_VALUE(final KEY_GENERIC_TYPE k, final VALUE_GENERIC_TYPE v, METHOD_ARG_VALUE_BINARY_OPERATOR remappingFunction) { + java.util.Objects.requireNonNull(remappingFunction); + REQUIRE_VALUE_NON_NULL(v) + + final int pos = find(k); + if (pos < 0) { + insert(-pos - 1, k, v); + return v; + } + + final VALUE_GENERIC_TYPE newValue = remappingFunction.VALUE_OPERATOR_APPLY(value[pos], v); + + return value[pos] = newValue; + } +#endif + /** {@inheritDoc} */ @Override public VALUE_GENERIC_TYPE merge(final KEY_GENERIC_TYPE k, final VALUE_GENERIC_TYPE v, final java.util.function.BiFunction remappingFunction) {