By default, purge-local-repository
will remove from the local repository all the files associated to the version of each dependency (including transitive) of the project it is ran on:
Remove the project dependencies from the local repository, and optionally re-resolve them.
The several factors coming into play are:
- Transitive dependencies are purged by the plugin by default; this is configurable through the
actTransitively
parameter.
- All of the purged artifacts from the local repository are re-resolved by default; this is configurable through the
reResolve
parameter.
- The actual files that are purged from the local repository correspond to all the files associated to the version of the purged artifact. For example, if the dependency
foo:bar:1.0
is purged, all the files under the path foo/bar/1.0/*
will be removed. This is configurable through the resolutionFuzziness
parameter (whose default value is version
):
- A value of
artifactId
would purge all the files under the path to artifact id of the artifact being purged. In the example above, all files under foo/bar/**
would be purged (so, all versions are removed).
- A value of
groupId
would purge all the files under the path to group id of the artifact being purged. In the example above, all files under foo/**
would be purged (so, all versions for all artifact ids are removed).
- A value of
file
would only purge the file for the artifact being purged. In the example above, only the files bar-1.0.jar*
will be removed (this includes any sha1
they could have). It would not purge the associated POM file.
You can see which artifacts are going to be purged by printing the list of all dependencies for the project with the list
goal:
mvn dependency:list
optionally adding excludeTransitive
to this command, if you decide not to purge transitive dependencies.