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

com.devonfw.tools.ide.migrator.builder.PomXmlMigrationBuilder Maven / Gradle / Ivy

package com.devonfw.tools.ide.migrator.builder;

import java.util.regex.Pattern;

import com.devonfw.tools.ide.migrator.file.XmlFileMigration;
import com.devonfw.tools.ide.migrator.version.VersionIdentifier;
import com.devonfw.tools.ide.migrator.xml.MavenDependencyAdder;
import com.devonfw.tools.ide.migrator.xml.MavenDependencyReplacement;
import com.devonfw.tools.ide.migrator.xml.MavenPropertyReplacement;
import com.devonfw.tools.ide.migrator.xml.XmlRegexReplacement;
import com.devonfw.tools.ide.migrator.xml.XmlStringReplacement;

/**
 * {@link XmlMigrationBuilder} for POM files.
 */
public class PomXmlMigrationBuilder extends XmlMigrationBuilder {

  /**
   * The constructor.
   *
   * @param parent the parent builder.
   */
  public PomXmlMigrationBuilder(MigrationStepBuilder parent) {

    super(parent, XmlFileMigration.POM_XML_PATTERN);
  }

  /**
   * @param pattern the {@link VersionIdentifier} for the dependency to match and replace.
   * @param replacement the {@link VersionIdentifier} with the replacement dependency.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder replaceDependency(VersionIdentifier pattern, VersionIdentifier replacement) {

    this.migration.getMigrations().add(new MavenDependencyReplacement(pattern, replacement));
    return this;
  }

  /**
   * @param projectPattern the {@link VersionIdentifier} of the maven project/module to match.
   * @param dependency the {@link VersionIdentifier} with the dependency to add.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder addDependency(VersionIdentifier projectPattern, VersionIdentifier dependency) {

    this.migration.getMigrations().add(new MavenDependencyAdder(projectPattern, dependency));
    return this;
  }

  /**
   * @param property the name of the Maven property to replace.
   * @param value the new value of the specified property.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder replaceProperty(String property, String value) {

    return replaceProperty(property, value, property);
  }

  /**
   * @param property the name of the Maven property to replace.
   * @param value the new value of the specified property.
   * @param newProperty the new name of the Maven property to replace.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder replaceProperty(String property, String value, String newProperty) {

    this.migration.getMigrations().add(new MavenPropertyReplacement(property, value, newProperty));
    return this;
  }

  /**
   * @param search the plain {@link String} to replace in POM.
   * @param replacement the replacement {@link String}.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder replaceString(String search, String replacement) {

    this.migration.getMigrations().add(new XmlStringReplacement(search, replacement));
    return this;
  }

  /**
   * @param pattern the plain {@link Pattern} to replace in POM.
   * @param replacement the replacement {@link String}.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder replaceRegex(String pattern, String replacement) {

    return replaceRegex(Pattern.compile(pattern), replacement);
  }

  /**
   * @param pattern the plain {@link Pattern} to replace in POM.
   * @param replacement the replacement {@link String}.
   * @return {@code this}.
   */
  public PomXmlMigrationBuilder replaceRegex(Pattern pattern, String replacement) {

    this.migration.getMigrations().add(new XmlRegexReplacement(pattern, replacement));
    return this;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy