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

io.codemodder.CodemodChange Maven / Gradle / Ivy

package io.codemodder;

import io.codemodder.codetf.CodeTFParameter;
import io.codemodder.codetf.FixedFinding;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import javax.annotation.Nullable;

/** Represents a change made to the code. */
public final class CodemodChange {

  /** Represents the original line number where this change was found to be applicable. */
  private final int lineNumber;

  /** Represents the dependencies required by the new code we introduced in this weave. */
  private final List dependenciesNeeded;

  /** The fixed finding that was addressed by this change. */
  private final List fixedFindings;

  /**
   * Represents the parameters that were used to generate the new code we introduced in this weave.
   */
  private final List parameters;

  /** Represents a description for this change to be used instead of the standard static text. */
  private @Nullable final String description;

  private CodemodChange(final int lineNumber, final List dependenciesNeeded) {
    this.lineNumber = lineNumber;
    this.dependenciesNeeded = Objects.requireNonNull(dependenciesNeeded, "dependenciesNeeded");
    this.parameters = List.of();
    this.description = null;
    this.fixedFindings = List.of();
  }

  private CodemodChange(
      final int lineNumber,
      final List dependenciesNeeded,
      final List fixedFindings) {
    this.lineNumber = lineNumber;
    this.dependenciesNeeded = Objects.requireNonNull(dependenciesNeeded, "dependenciesNeeded");
    this.parameters = List.of();
    this.description = null;
    this.fixedFindings = fixedFindings;
  }

  private CodemodChange(final int lineNumber, final FixedFinding finding) {
    this.lineNumber = lineNumber;
    this.dependenciesNeeded = List.of();
    this.parameters = List.of();
    this.description = null;
    this.fixedFindings = List.of(Objects.requireNonNull(finding));
  }

  private CodemodChange(
      final int lineNumber, final String description, final List findings) {
    this.lineNumber = lineNumber;
    this.dependenciesNeeded = List.of();
    this.parameters = List.of();
    this.description = description;
    this.fixedFindings = Objects.requireNonNull(findings);
  }

  private CodemodChange(final int lineNumber, final String description) {
    this.lineNumber = lineNumber;
    this.dependenciesNeeded = List.of();
    this.parameters = List.of();
    this.description = Objects.requireNonNull(description);
    this.fixedFindings = List.of();
  }

  private CodemodChange(final int lineNumber, final Parameter parameter, final String valueUsed) {
    this.lineNumber = lineNumber;
    this.dependenciesNeeded = List.of();
    CodeTFParameter codeTFParameter =
        new CodeTFParameter(
            parameter.getQuestion(),
            parameter.getName(),
            parameter.getType(),
            parameter.getLabel(),
            valueUsed);
    this.parameters = List.of(codeTFParameter);
    this.description = null;
    this.fixedFindings = List.of();
  }

  @Override
  public boolean equals(final Object o) {
    if (this == o) return true;
    if (o == null || getClass() != o.getClass()) return false;
    final CodemodChange weave = (CodemodChange) o;
    return lineNumber == weave.lineNumber && dependenciesNeeded.equals(weave.dependenciesNeeded);
  }

  @Override
  public int hashCode() {
    return Objects.hash(lineNumber, dependenciesNeeded);
  }

  /**
   * The line number associated with the change. Doesn't necessarily mean the line where it starts,
   * ends, or was discovered, but should be deterministic on consecutive runs.
   */
  public int lineNumber() {
    return lineNumber;
  }

  /** A list of the codemod parameters that are involved in this change. */
  public List getParameters() {
    return parameters;
  }

  /**
   * A list of the dependencies that are required to be added to the project in order to support
   * this change.
   */
  public List getDependenciesNeeded() {
    return dependenciesNeeded;
  }

  /**
   * A description of the change that is being made. If not provided, the default description will
   * be used.
   */
  public Optional getDescription() {
    return Optional.ofNullable(description);
  }

  /** The fixed finding that was addressed by this change. */
  public List getFixedFindings() {
    return fixedFindings;
  }

  /** Builds a weave. */
  public static CodemodChange from(final int line, final List dependenciesNeeded) {
    return new CodemodChange(line, dependenciesNeeded);
  }

  /**
   * A {@link CodemodChange} convenience builder for weaves that only requires one new dependency.
   * Equivalent to calling: {@code CodemodChange.from(line, code, List.of(dependencyNeeded))}
   */
  public static CodemodChange from(final int line, final DependencyGAV dependencyNeeded) {
    return new CodemodChange(line, List.of(dependencyNeeded));
  }

  /**
   * A {@link CodemodChange} convenience builder for weaves that don't require a new dependency.
   * Equivalent to calling: {@code CodemodChange.from(line, code, List.of())}
   */
  public static CodemodChange from(final int line) {
    return new CodemodChange(line, List.of());
  }

  public static CodemodChange from(final int line, final FixedFinding finding) {
    return new CodemodChange(line, finding);
  }

  public static CodemodChange from(
      final int line, final List dependencyGAVS, final FixedFinding finding) {
    return new CodemodChange(line, dependencyGAVS, List.of(finding));
  }

  public static CodemodChange from(
      final int line, final List dependencyGAVS, final List finding) {
    return new CodemodChange(line, dependencyGAVS, finding);
  }

  public static CodemodChange from(
      final int line, final String description, final FixedFinding finding) {
    return new CodemodChange(line, description, List.of(finding));
  }

  public static CodemodChange from(
      final int line, final String description, final List findings) {
    return new CodemodChange(line, description, findings);
  }

  public static CodemodChange from(
      final int line, final Parameter parameter, final String valueUsed) {
    return new CodemodChange(line, parameter, valueUsed);
  }

  public static CodemodChange from(final int line, final String description) {
    return new CodemodChange(line, description);
  }

  @Override
  public String toString() {
    return "CodemodChange{"
        + "lineNumber="
        + lineNumber
        + ", dependenciesNeeded="
        + dependenciesNeeded
        + ", parameters="
        + parameters
        + ", description="
        + description
        + '}';
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy