From 952fbd64943799e483793605fbd4d6aa2015a52f Mon Sep 17 00:00:00 2001 From: Lauri Tulmin Date: Mon, 28 Feb 2022 20:57:35 +0200 Subject: [PATCH] Fix android desugaring for HashMap.forEach --- .../api/instrumenter/UnsafeAttributes.java | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/instrumentation-api/src/main/java/io/opentelemetry/instrumentation/api/instrumenter/UnsafeAttributes.java b/instrumentation-api/src/main/java/io/opentelemetry/instrumentation/api/instrumenter/UnsafeAttributes.java index 9284d1a062a3..5d08e9fb20b3 100644 --- a/instrumentation-api/src/main/java/io/opentelemetry/instrumentation/api/instrumenter/UnsafeAttributes.java +++ b/instrumentation-api/src/main/java/io/opentelemetry/instrumentation/api/instrumenter/UnsafeAttributes.java @@ -10,6 +10,7 @@ import io.opentelemetry.api.common.AttributesBuilder; import java.util.HashMap; import java.util.Map; +import java.util.function.BiConsumer; /** * The {@link AttributesBuilder} and {@link Attributes} used by the instrumentation API. We are able @@ -68,4 +69,12 @@ public AttributesBuilder putAll(Attributes attributes) { attributes.forEach(this::put); return this; } + + @Override + public void forEach(BiConsumer, ? super Object> action) { + // https://github.com/open-telemetry/opentelemetry-java/issues/4161 + // Help out android desugaring by having an explicit call to HashMap.forEach, when forEach is + // just called through Attributes.forEach desugaring is unable to correctly handle it. + super.forEach(action); + } }