org.openrewrite.java.dependencies.RemoveDependency
For Gradle project, removes a single dependency from the dependencies section of the build.gradle
.
For Maven project, removes a single dependency from the section of the pom.xml.
GitHub, Issue Tracker, Maven Central
- groupId: org.openrewrite.recipe
- artifactId: rewrite-java-dependencies
- version: 1.0.1
Type | Name | Description |
---|---|---|
String |
groupId | The first part of a dependency coordinate com.google.guava:guava:VERSION . This can be a glob expression. |
String |
artifactId | The second part of a dependency coordinate com.google.guava:guava:VERSION . This can be a glob expression. |
String |
configuration | Optional. The dependency configuration to remove from. |
String |
scope | Optional. Only remove dependencies if they are in this scope. If 'runtime', this willalso remove dependencies in the 'compile' scope because 'compile' dependencies are part of the runtime dependency set |
Remove a Gradle dependency
Parameter | Value |
---|---|
groupId | org.springframework.boot |
artifactId | spring-boot* |
configuration | null |
scope | null |
{% tabs %} {% tab title="build.gradle" %}
{% code title="build.gradle" %}
plugins {
id 'java-library'
}
repositories {
mavenCentral()
}
dependencies {
implementation("org.springframework.boot:spring-boot-starter-web:2.7.0") {
exclude group: "junit"
}
testImplementation "org.junit.vintage:junit-vintage-engine:5.6.2"
}
{% endcode %}
{% code title="build.gradle" %}
plugins {
id 'java-library'
}
repositories {
mavenCentral()
}
dependencies {
testImplementation "org.junit.vintage:junit-vintage-engine:5.6.2"
}
{% endcode %}
{% endtab %} {% tab title="Diff" %} {% code %}
--- build.gradle
+++ build.gradle
@@ -10,3 +10,0 @@
dependencies {
- implementation("org.springframework.boot:spring-boot-starter-web:2.7.0") {
- exclude group: "junit"
- }
testImplementation "org.junit.vintage:junit-vintage-engine:5.6.2"
{% endcode %} {% endtab %} {% endtabs %}
Remove a Maven dependency
Parameter | Value |
---|---|
groupId | junit |
artifactId | junit |
configuration | null |
scope | null |
{% tabs %} {% tab title="pom.xml" %}
{% code title="pom.xml" %}
<project>
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany.app</groupId>
<artifactId>my-app</artifactId>
<version>1</version>
<dependencies>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>29.0-jre</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.1</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
{% endcode %}
{% code title="pom.xml" %}
<project>
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany.app</groupId>
<artifactId>my-app</artifactId>
<version>1</version>
<dependencies>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>29.0-jre</version>
</dependency>
</dependencies>
</project>
{% endcode %}
{% endtab %} {% tab title="Diff" %} {% code %}
--- pom.xml
+++ pom.xml
@@ -14,6 +14,0 @@
<version>29.0-jre</version>
</dependency>
- <dependency>
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>4.13.1</version>
- <scope>test</scope>
- </dependency>
</dependencies>
{% endcode %} {% endtab %} {% endtabs %}
This recipe has required configuration parameters. Recipes with required configuration parameters cannot be activated directly. To activate this recipe you must create a new recipe which fills in the required parameters. In your rewrite.yml
create a new recipe with a unique name. For example: com.yourorg.RemoveDependencyExample
.
Here's how you can define and customize such a recipe within your rewrite.yml:
{% code title="rewrite.yml" %}
---
type: specs.openrewrite.org/v1beta/recipe
name: com.yourorg.RemoveDependencyExample
displayName: Remove a Gradle or Maven dependency example
recipeList:
- org.openrewrite.java.dependencies.RemoveDependency:
groupId: com.fasterxml.jackson*
artifactId: jackson-module*
configuration: api
scope: compile
{% endcode %}
Now that com.yourorg.RemoveDependencyExample
has been defined activate it and take a dependency on org.openrewrite.recipe:rewrite-java-dependencies:1.0.1 in your build file:
{% tabs %}
{% tab title="Gradle" %}
{% code title="build.gradle" %}
plugins {
id("org.openrewrite.rewrite") version("6.1.4")
}
rewrite {
activeRecipe("com.yourorg.RemoveDependencyExample")
}
repositories {
mavenCentral()
}
dependencies {
rewrite("org.openrewrite.recipe:rewrite-java-dependencies:1.0.1")
}
{% endcode %} {% endtab %} {% tab title="Maven" %} {% code title="pom.xml" %}
<project>
<build>
<plugins>
<plugin>
<groupId>org.openrewrite.maven</groupId>
<artifactId>rewrite-maven-plugin</artifactId>
<version>5.2.4</version>
<configuration>
<activeRecipes>
<recipe>com.yourorg.RemoveDependencyExample</recipe>
</activeRecipes>
</configuration>
<dependencies>
<dependency>
<groupId>org.openrewrite.recipe</groupId>
<artifactId>rewrite-java-dependencies</artifactId>
<version>1.0.1</version>
</dependency>
</dependencies>
</plugin>
</plugins>
</build>
</project>
{% endcode %} {% endtab %} {% endtabs %}
{% tabs %} {% tab title="Recipe List" %}
- Remove a Gradle dependency
- groupId: ``
- artifactId: ``
- configuration: ``
- Remove Maven dependency
- groupId: ``
- artifactId: ``
- scope: ``
{% endtab %}
{% tab title="Yaml Recipe List" %}
---
type: specs.openrewrite.org/v1beta/recipe
name: org.openrewrite.java.dependencies.RemoveDependency
displayName: Remove a Gradle or Maven dependency
description: For Gradle project, removes a single dependency from the dependencies section of the `build.gradle`.
For Maven project, removes a single dependency from the <dependencies> section of the pom.xml.
groupId:
artifactId:
configuration:
scope:
recipeList:
- org.openrewrite.gradle.RemoveDependency:
groupId:
artifactId:
configuration:
- org.openrewrite.maven.RemoveDependency:
groupId:
artifactId:
scope:
{% endtab %} {% endtabs %}
The community edition of the Moderne platform enables you to easily run recipes across thousands of open-source repositories.
Please contact Moderne for more information about safely running the recipes on your own codebase in a private SaaS.