From 8f4e6be40709df142c96825cde0a74e459f1ec4f Mon Sep 17 00:00:00 2001 From: Slawomir Jaranowski Date: Fri, 20 Oct 2023 22:37:05 +0200 Subject: [PATCH] read-project-properties optimization - set all properties in one call In Maven 4 project model will be immutable each change in project will cause rebuild it again so minimize call counts for changing properties --- .../mojo/properties/ReadPropertiesMojo.java | 30 ++++++++++++++++--- 1 file changed, 26 insertions(+), 4 deletions(-) diff --git a/src/main/java/org/codehaus/mojo/properties/ReadPropertiesMojo.java b/src/main/java/org/codehaus/mojo/properties/ReadPropertiesMojo.java index 6f92d04..09c1342 100644 --- a/src/main/java/org/codehaus/mojo/properties/ReadPropertiesMojo.java +++ b/src/main/java/org/codehaus/mojo/properties/ReadPropertiesMojo.java @@ -27,6 +27,9 @@ import java.net.MalformedURLException; import java.net.URL; import java.util.Enumeration; +import java.util.HashMap; +import java.util.Map; +import java.util.Objects; import java.util.Properties; import org.apache.maven.plugin.AbstractMojo; @@ -188,13 +191,17 @@ private void loadProperties(Resource resource) throws MojoExecutionException { Properties properties = new Properties(); properties.load(stream); Properties projectProperties = project.getProperties(); + Map newProperties = new HashMap<>(); for (String key : properties.stringPropertyNames()) { String propertyName = effectivePrefix + key; if (override || !projectProperties.containsKey(propertyName)) { - projectProperties.put(propertyName, properties.get(key)); + newProperties.put(propertyName, properties.getProperty(key)); } } + // change project properties at one call + projectProperties.putAll(newProperties); + getLog().info("Loading " + newProperties.size() + " properties from " + resource); } } catch (IOException e) { throw new MojoExecutionException("Error reading properties from " + resource, e); @@ -210,13 +217,28 @@ private void missing(Resource resource) throws MojoExecutionException { } private void resolveProperties() throws MojoExecutionException, MojoFailureException { + getLog().debug("resolve properties"); Properties environment = loadSystemEnvironmentPropertiesWhenDefined(); Properties projectProperties = project.getProperties(); - for (Enumeration n = projectProperties.propertyNames(); n.hasMoreElements(); ) { - String k = (String) n.nextElement(); - projectProperties.setProperty(k, getPropertyValue(k, projectProperties, environment)); + Map newProperties = new HashMap<>(); + + for (String key : projectProperties.stringPropertyNames()) { + String newValue = getPropertyValue(key, projectProperties, environment); + String oldValue = projectProperties.getProperty(key); + if (!Objects.equals(newValue, oldValue)) { + newProperties.put(key, newValue); + } + } + + if (!newProperties.isEmpty()) { + getLog().debug("resolve " + newProperties.size() + " properties"); + // change project properties at one call + projectProperties.putAll(newProperties); + } else { + getLog().debug("all properties was resolved"); } + getLog().debug("resolve properties - done"); } private Properties loadSystemEnvironmentPropertiesWhenDefined() throws MojoExecutionException {