com.github.ferstl.maven.pomenforcers.PedanticModuleOrderEnforcer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pedantic-pom-enforcers Show documentation
Show all versions of pedantic-pom-enforcers Show documentation
The Pedantic POM Enforcers consist of serveral Maven enforcer rules that help you keep your
project setup consistent and organized.
/*
* Copyright (c) 2012 by The Author(s)
*
* Licensed 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 com.github.ferstl.maven.pomenforcers;
import java.util.List;
import java.util.Set;
import org.apache.maven.enforcer.rule.api.EnforcerRuleException;
import org.apache.maven.enforcer.rule.api.EnforcerRuleHelper;
import org.apache.maven.plugin.logging.Log;
import org.apache.maven.project.MavenProject;
import org.w3c.dom.Document;
import com.github.ferstl.maven.pomenforcers.reader.DeclaredModulesReader;
import com.github.ferstl.maven.pomenforcers.reader.XPathExpressions;
import com.github.ferstl.maven.pomenforcers.util.CommaSeparatorUtils;
import com.github.ferstl.maven.pomenforcers.util.EnforcerRuleUtils;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Ordering;
import com.google.common.collect.Sets;
/**
* This enforcer makes sure that your modules
section is sorted
* alphabetically. Modules that should occur at a specific position in the
* <modules>
section can be ignored.
*
*
* ### Example
* <rules>
* <moduleOrder implementation="com.github.ferstl.maven.pomenforcers.PedanticModuleOrderEnforcer">
* <!-- These modules may occur at any place in the modules section -->
* <ignoredModules>dist-deb,dist-rpm</ignoredModules>
* </moduleOrder>
* </rules>
*
*
* @id {@link PedanticEnforcerRule#MODULE_ORDER}
*/
public class PedanticModuleOrderEnforcer extends AbstractPedanticEnforcer {
/** All modules in this set won't be checked for the correct order. */
private final Set ignoredModules;
public PedanticModuleOrderEnforcer() {
this.ignoredModules = Sets.newLinkedHashSet();
}
/**
* Comma-separated list of ignored modules. All modules in this list may occur at any place in the
* modules
section.
* @param ignoredModules Comma-separated list of ignored modules.
* @configParam
*/
public void setIgnoredModules(String ignoredModules) {
CommaSeparatorUtils.splitAndAddToCollection(ignoredModules, this.ignoredModules);
}
@Override
protected void doEnforce(EnforcerRuleHelper helper, Document pom) throws EnforcerRuleException {
MavenProject project = EnforcerRuleUtils.getMavenProject(helper);
// Do nothing if the project is not a parent project
if (!isPomProject(project)) {
return;
}
Log log = helper.getLog();
log.info("Enforcing alphabetical module order.");
log.info(" -> These modules are ignored: " + CommaSeparatorUtils.join(this.ignoredModules));
// Remove all modules to be ignored.
List declaredModules = new DeclaredModulesReader(pom).read(XPathExpressions.POM_MODULES);
declaredModules.removeAll(this.ignoredModules);
// Enforce the module order
Ordering moduleOrdering = Ordering.natural();
if (!moduleOrdering.isOrdered(declaredModules)) {
ImmutableList orderedModules = moduleOrdering.immutableSortedCopy(declaredModules);
String message = "One does not simply declare modules! "
+ "You have to sort your modules alphabetically: " + orderedModules;
if (!this.ignoredModules.isEmpty()) {
message += " You may place these modules in any order: " + this.ignoredModules;
}
throw new EnforcerRuleException(message);
}
}
@Override
protected void accept(PedanticEnforcerVisitor visitor) {
visitor.visit(this);
}
private boolean isPomProject(MavenProject project) {
return "pom".equals(project.getPackaging());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy