All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.maven.plugin.resources.remote.ModelUtils Maven / Gradle / Ivy

Go to download

Process resources packaged in JARs that have been deployed to a remote repository. The primary use case being satisfied is the consistent inclusion of common resources in a large set of projects. Maven projects at Apache use this plug-in to satisfy licensing requirements at Apache where each project must include license and notice files for each release.

There is a newer version: 3.2.0
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.maven.plugin.resources.remote;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.TreeMap;

import org.apache.maven.model.Dependency;
import org.apache.maven.model.Plugin;
import org.apache.maven.model.PluginContainer;
import org.apache.maven.model.PluginExecution;
import org.apache.maven.model.Repository;
import org.codehaus.plexus.util.xml.Xpp3Dom;

/** HELPER CLASS */
public final class ModelUtils {

    /**
     * This should be the resulting ordering of plugins after merging:
     * 

* Given: *

     * parent: X -> A -> B -> D -> E
     * child: Y -> A -> C -> D -> F
     * 
* Result: *
     * X -> Y -> A -> B -> C -> D -> E -> F
     * 
*/ public static void mergePluginLists( PluginContainer childContainer, PluginContainer parentContainer, boolean handleAsInheritance) { if ((childContainer == null) || (parentContainer == null)) { // nothing to do. return; } List parentPlugins = parentContainer.getPlugins(); if ((parentPlugins != null) && !parentPlugins.isEmpty()) { parentPlugins = new ArrayList<>(parentPlugins); // If we're processing this merge as an inheritance, we have to build up a list of // plugins that were considered for inheritance. if (handleAsInheritance) { for (Iterator it = parentPlugins.iterator(); it.hasNext(); ) { Plugin plugin = it.next(); String inherited = plugin.getInherited(); if ((inherited != null) && !Boolean.parseBoolean(inherited)) { it.remove(); } } } List assembledPlugins = new ArrayList<>(); Map childPlugins = childContainer.getPluginsAsMap(); for (Plugin parentPlugin : parentPlugins) { String parentInherited = parentPlugin.getInherited(); // only merge plugin definition from the parent if at least one // of these is true: // 1. we're not processing the plugins in an inheritance-based merge // 2. the parent's flag is not set // 3. the parent's flag is set to true if (!handleAsInheritance || (parentInherited == null) || Boolean.parseBoolean(parentInherited)) { Plugin childPlugin = childPlugins.get(parentPlugin.getKey()); if ((childPlugin != null) && !assembledPlugins.contains(childPlugin)) { Plugin assembledPlugin = childPlugin; mergePluginDefinitions(childPlugin, parentPlugin, handleAsInheritance); // fix for MNG-2221 (assembly cache was not being populated for later reference): assembledPlugins.add(assembledPlugin); } // if we're processing this as an inheritance-based merge, and // the parent's flag is not set, then we need to // clear the inherited flag in the merge result. if (handleAsInheritance && (parentInherited == null)) { parentPlugin.unsetInheritanceApplied(); } } // very important to use the parentPlugins List, rather than parentContainer.getPlugins() // since this list is a local one, and may have been modified during processing. List results = ModelUtils.orderAfterMerge(assembledPlugins, parentPlugins, childContainer.getPlugins()); childContainer.setPlugins(results); childContainer.flushPluginMap(); } } } public static List orderAfterMerge( List merged, List highPrioritySource, List lowPrioritySource) { List results = new ArrayList<>(); if (!merged.isEmpty()) { results.addAll(merged); } List missingFromResults = new ArrayList<>(); List> sources = new ArrayList<>(); sources.add(highPrioritySource); sources.add(lowPrioritySource); for (List source : sources) { for (Plugin item : source) { if (results.contains(item)) { if (!missingFromResults.isEmpty()) { int idx = results.indexOf(item); if (idx < 0) { idx = 0; } results.addAll(idx, missingFromResults); missingFromResults.clear(); } } else { missingFromResults.add(item); } } if (!missingFromResults.isEmpty()) { results.addAll(missingFromResults); missingFromResults.clear(); } } return results; } public static void mergePluginDefinitions(Plugin child, Plugin parent, boolean handleAsInheritance) { if ((child == null) || (parent == null)) { // nothing to do. return; } if (parent.isExtensions()) { child.setExtensions(true); } if ((child.getVersion() == null) && (parent.getVersion() != null)) { child.setVersion(parent.getVersion()); } Xpp3Dom childConfiguration = (Xpp3Dom) child.getConfiguration(); Xpp3Dom parentConfiguration = (Xpp3Dom) parent.getConfiguration(); childConfiguration = Xpp3Dom.mergeXpp3Dom(childConfiguration, parentConfiguration); child.setConfiguration(childConfiguration); child.setDependencies(mergeDependencyList(child.getDependencies(), parent.getDependencies())); // from here to the end of the method is dealing with merging of the section. String parentInherited = parent.getInherited(); boolean parentIsInherited = (parentInherited == null) || Boolean.parseBoolean(parentInherited); List parentExecutions = parent.getExecutions(); if ((parentExecutions != null) && !parentExecutions.isEmpty()) { List mergedExecutions = new ArrayList<>(); Map assembledExecutions = new TreeMap<>(); Map childExecutions = child.getExecutionsAsMap(); for (PluginExecution parentExecution : parentExecutions) { String inherited = parentExecution.getInherited(); boolean parentExecInherited = parentIsInherited && ((inherited == null) || Boolean.parseBoolean(inherited)); if (!handleAsInheritance || parentExecInherited) { PluginExecution assembled = parentExecution; PluginExecution childExecution = childExecutions.get(parentExecution.getId()); if (childExecution != null) { mergePluginExecutionDefinitions(childExecution, parentExecution); assembled = childExecution; } else if (handleAsInheritance && (parentInherited == null)) { parentExecution.unsetInheritanceApplied(); } assembledExecutions.put(assembled.getId(), assembled); mergedExecutions.add(assembled); } } for (PluginExecution childExecution : child.getExecutions()) { if (!assembledExecutions.containsKey(childExecution.getId())) { mergedExecutions.add(childExecution); } } child.setExecutions(mergedExecutions); child.flushExecutionMap(); } } private static void mergePluginExecutionDefinitions(PluginExecution child, PluginExecution parent) { if (child.getPhase() == null) { child.setPhase(parent.getPhase()); } List parentGoals = parent.getGoals(); List childGoals = child.getGoals(); List goals = new ArrayList<>(); if ((childGoals != null) && !childGoals.isEmpty()) { goals.addAll(childGoals); } if (parentGoals != null) { for (String goal : parentGoals) { if (!goals.contains(goal)) { goals.add(goal); } } } child.setGoals(goals); Xpp3Dom childConfiguration = (Xpp3Dom) child.getConfiguration(); Xpp3Dom parentConfiguration = (Xpp3Dom) parent.getConfiguration(); childConfiguration = Xpp3Dom.mergeXpp3Dom(childConfiguration, parentConfiguration); child.setConfiguration(childConfiguration); } public static List mergeRepositoryLists(List dominant, List recessive) { List repositories = new ArrayList<>(dominant); for (Repository repository : recessive) { if (!repositories.contains(repository)) { repositories.add(repository); } } return repositories; } public static void mergeFilterLists(List childFilters, List parentFilters) { for (String f : parentFilters) { if (!childFilters.contains(f)) { childFilters.add(f); } } } private static List mergeDependencyList(List child, List parent) { Map depsMap = new LinkedHashMap<>(); if (parent != null) { for (Dependency dependency : parent) { depsMap.put(dependency.getManagementKey(), dependency); } } if (child != null) { for (Dependency dependency : child) { depsMap.put(dependency.getManagementKey(), dependency); } } return new ArrayList<>(depsMap.values()); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy