From 837a603df8f278fc54900bca045ec0e5240beb43 Mon Sep 17 00:00:00 2001 From: Roberto Cortez Date: Thu, 28 Nov 2024 21:38:55 +0000 Subject: [PATCH] Fix NPE caused by PropertyName map with Mappings names --- .../BuildTimeConfigurationReader.java | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java b/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java index 052ee5e5a0e52..3b875da246b2a 100644 --- a/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java +++ b/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java @@ -21,6 +21,7 @@ import java.lang.reflect.Type; import java.util.ArrayList; import java.util.Collections; +import java.util.Comparator; import java.util.HashMap; import java.util.HashSet; import java.util.List; @@ -1231,18 +1232,13 @@ private static Map mappingsToNames(final List for (String name : names) { PropertyName propertyName = new PropertyName(name); if (propertyNames.containsKey(propertyName)) { - String existing = propertyNames.remove(propertyName); - if (existing.length() < name.length()) { - propertyNames.put(new PropertyName(existing), existing); - } else if (existing.length() > name.length()) { - propertyNames.put(propertyName, name); - } else { - if (existing.indexOf('*') <= name.indexOf('*')) { - propertyNames.put(new PropertyName(existing), existing); - } else { - propertyNames.put(propertyName, name); - } + List duplicates = new ArrayList<>(); + duplicates.add(name); + while (propertyNames.containsKey(propertyName)) { + duplicates.add(propertyNames.remove(propertyName)); } + String minName = Collections.min(duplicates, Comparator.comparingInt(String::length)); + propertyNames.put(new PropertyName(minName), minName); } else { propertyNames.put(propertyName, name); }