This is an automated email from the ASF dual-hosted git repository.

gnodet pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/maven.git


The following commit(s) were added to refs/heads/master by this push:
     new 56ee6a878d [MNG-7751] Provide a way to inject XmlNode into plugins 
(#1071)
56ee6a878d is described below

commit 56ee6a878d25ebeee01f9a4f7431b35aced945a4
Author: Guillaume Nodet <[email protected]>
AuthorDate: Mon Jun 12 21:39:23 2023 +0200

    [MNG-7751] Provide a way to inject XmlNode into plugins (#1071)
---
 .../internal/DefaultBeanConfigurator.java          | 40 ++++++++++++++++++++++
 .../internal/EnhancedConverterLookup.java          |  1 +
 2 files changed, 41 insertions(+)

diff --git 
a/maven-core/src/main/java/org/apache/maven/configuration/internal/DefaultBeanConfigurator.java
 
b/maven-core/src/main/java/org/apache/maven/configuration/internal/DefaultBeanConfigurator.java
index 7053409804..732a9d8ad8 100644
--- 
a/maven-core/src/main/java/org/apache/maven/configuration/internal/DefaultBeanConfigurator.java
+++ 
b/maven-core/src/main/java/org/apache/maven/configuration/internal/DefaultBeanConfigurator.java
@@ -24,15 +24,20 @@ import javax.inject.Singleton;
 import java.io.File;
 import java.nio.file.Path;
 import java.nio.file.Paths;
+import java.util.ArrayList;
+import java.util.List;
 import java.util.Objects;
 
+import org.apache.maven.api.xml.XmlNode;
 import org.apache.maven.configuration.BeanConfigurationException;
 import org.apache.maven.configuration.BeanConfigurationPathTranslator;
 import org.apache.maven.configuration.BeanConfigurationRequest;
 import org.apache.maven.configuration.BeanConfigurationValuePreprocessor;
 import org.apache.maven.configuration.BeanConfigurator;
+import org.apache.maven.internal.xml.XmlNodeImpl;
 import 
org.codehaus.plexus.component.configurator.ComponentConfigurationException;
 import org.codehaus.plexus.component.configurator.ConfigurationListener;
+import 
org.codehaus.plexus.component.configurator.converters.AbstractConfigurationConverter;
 import 
org.codehaus.plexus.component.configurator.converters.basic.AbstractBasicConverter;
 import 
org.codehaus.plexus.component.configurator.converters.composite.ObjectWithFieldsConverter;
 import 
org.codehaus.plexus.component.configurator.converters.lookup.ConverterLookup;
@@ -133,6 +138,41 @@ public class DefaultBeanConfigurator implements 
BeanConfigurator {
         }
     }
 
+    static class XmlConverter extends AbstractConfigurationConverter {
+        @Override
+        public boolean canConvert(Class<?> type) {
+            return XmlNode.class.equals(type);
+        }
+
+        @Override
+        public Object fromConfiguration(
+                final ConverterLookup lookup,
+                final PlexusConfiguration configuration,
+                final Class<?> type,
+                final Class<?> enclosingType,
+                final ClassLoader loader,
+                final ExpressionEvaluator evaluator,
+                final ConfigurationListener listener)
+                throws ComponentConfigurationException {
+
+            try {
+                return toXml(configuration, evaluator);
+            } catch (ExpressionEvaluationException e) {
+                throw new ComponentConfigurationException("Unable to convert 
configuration to xml node", e);
+            }
+        }
+
+        XmlNode toXml(PlexusConfiguration config, ExpressionEvaluator 
evaluator) throws ExpressionEvaluationException {
+            List<XmlNode> children = new ArrayList<>();
+            for (PlexusConfiguration c : config.getChildren()) {
+                children.add(toXml(c, evaluator));
+            }
+            String name = config.getName();
+            Object value = evaluator.evaluate(config.getValue());
+            return new XmlNodeImpl(name, value != null ? value.toString() : 
null, null, children, null);
+        }
+    }
+
     static class PathConverter extends AbstractBasicConverter {
         @Override
         public boolean canConvert(Class<?> type) {
diff --git 
a/maven-core/src/main/java/org/apache/maven/configuration/internal/EnhancedConverterLookup.java
 
b/maven-core/src/main/java/org/apache/maven/configuration/internal/EnhancedConverterLookup.java
index e8c2ed1a19..55c2a5c864 100644
--- 
a/maven-core/src/main/java/org/apache/maven/configuration/internal/EnhancedConverterLookup.java
+++ 
b/maven-core/src/main/java/org/apache/maven/configuration/internal/EnhancedConverterLookup.java
@@ -29,6 +29,7 @@ class EnhancedConverterLookup implements ConverterLookup {
 
     EnhancedConverterLookup() {
         registerConverter(new DefaultBeanConfigurator.PathConverter());
+        registerConverter(new DefaultBeanConfigurator.XmlConverter());
     }
 
     @Override

Reply via email to