This is an automated email from the ASF dual-hosted git repository. slachiewicz pushed a commit to branch MNG-6633 in repository https://gitbox.apache.org/repos/asf/maven.git
commit 790dc0f2b73c07a478802cbd0183fc8bd2f3fe78 Author: Stefan Oehme <st.oe...@gmail.com> AuthorDate: Mon Apr 29 15:31:34 2019 +0200 [MNG-6633] - Reduce memory usage of excludes ExcludesArtifactFilter was highly inefficient. It took the group and artifact ID of an Exclusion, concatenated them into a new String, which was kept in memory for the whole duration of the build and then compared that String against the concatenation of group and artifact ID of each incoming artifact, adding more CPU cycles than necessary. Instead we now just wrap the existing Exclusion object and check its groupId and artifactId against the artifact to tell whether it should be excluded. The old class is kept around for binary compatibility, but is now unused. Closes #243 --- .../resolver/filter/ExclusionArtifactFilter.java | 30 ++++++++++++++++++++++ .../apache/maven/bridge/MavenRepositorySystem.java | 12 ++------- .../project/artifact/MavenMetadataSource.java | 12 ++------- 3 files changed, 34 insertions(+), 20 deletions(-) diff --git a/maven-core/src/main/java/org/apache/maven/artifact/resolver/filter/ExclusionArtifactFilter.java b/maven-core/src/main/java/org/apache/maven/artifact/resolver/filter/ExclusionArtifactFilter.java new file mode 100644 index 0000000..b51350d --- /dev/null +++ b/maven-core/src/main/java/org/apache/maven/artifact/resolver/filter/ExclusionArtifactFilter.java @@ -0,0 +1,30 @@ +package org.apache.maven.artifact.resolver.filter; + +import java.util.List; + +import org.apache.maven.artifact.Artifact; +import org.apache.maven.model.Exclusion; + +public class ExclusionArtifactFilter implements ArtifactFilter +{ + private final List<Exclusion> exclusions; + + public ExclusionArtifactFilter( List<Exclusion> exclusions ) + { + this.exclusions = exclusions; + } + + @Override + public boolean include( Artifact artifact ) + { + for ( Exclusion exclusion : exclusions ) + { + if ( exclusion.getGroupId().equals( artifact.getGroupId() ) + && exclusion.getArtifactId().equals( artifact.getArtifactId() ) ) + { + return false; + } + } + return true; + } +} diff --git a/maven-core/src/main/java/org/apache/maven/bridge/MavenRepositorySystem.java b/maven-core/src/main/java/org/apache/maven/bridge/MavenRepositorySystem.java index 8558ae4..730b428 100644 --- a/maven-core/src/main/java/org/apache/maven/bridge/MavenRepositorySystem.java +++ b/maven-core/src/main/java/org/apache/maven/bridge/MavenRepositorySystem.java @@ -44,12 +44,11 @@ import org.apache.maven.artifact.repository.MavenArtifactRepository; import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout; import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout2; import org.apache.maven.artifact.repository.layout.DefaultRepositoryLayout; -import org.apache.maven.artifact.resolver.filter.ExcludesArtifactFilter; +import org.apache.maven.artifact.resolver.filter.ExclusionArtifactFilter; import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException; import org.apache.maven.artifact.versioning.VersionRange; import org.apache.maven.execution.MavenExecutionRequest; import org.apache.maven.model.Dependency; -import org.apache.maven.model.Exclusion; import org.apache.maven.model.Plugin; import org.apache.maven.repository.Proxy; import org.apache.maven.repository.RepositorySystem; @@ -116,14 +115,7 @@ public class MavenRepositorySystem if ( !d.getExclusions().isEmpty() ) { - List<String> exclusions = new ArrayList<>(); - - for ( Exclusion exclusion : d.getExclusions() ) - { - exclusions.add( exclusion.getGroupId() + ':' + exclusion.getArtifactId() ); - } - - artifact.setDependencyFilter( new ExcludesArtifactFilter( exclusions ) ); + artifact.setDependencyFilter( new ExclusionArtifactFilter( d.getExclusions() ) ); } return artifact; diff --git a/maven-core/src/main/java/org/apache/maven/project/artifact/MavenMetadataSource.java b/maven-core/src/main/java/org/apache/maven/project/artifact/MavenMetadataSource.java index 2dc9372..d002f17 100644 --- a/maven-core/src/main/java/org/apache/maven/project/artifact/MavenMetadataSource.java +++ b/maven-core/src/main/java/org/apache/maven/project/artifact/MavenMetadataSource.java @@ -47,7 +47,7 @@ import org.apache.maven.artifact.resolver.ArtifactResolutionException; import org.apache.maven.artifact.resolver.MultipleArtifactsNotFoundException; import org.apache.maven.artifact.resolver.filter.AndArtifactFilter; import org.apache.maven.artifact.resolver.filter.ArtifactFilter; -import org.apache.maven.artifact.resolver.filter.ExcludesArtifactFilter; +import org.apache.maven.artifact.resolver.filter.ExclusionArtifactFilter; import org.apache.maven.artifact.versioning.ArtifactVersion; import org.apache.maven.artifact.versioning.DefaultArtifactVersion; import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException; @@ -55,7 +55,6 @@ import org.apache.maven.artifact.versioning.VersionRange; import org.apache.maven.model.Dependency; import org.apache.maven.model.DependencyManagement; import org.apache.maven.model.DistributionManagement; -import org.apache.maven.model.Exclusion; import org.apache.maven.model.Relocation; import org.apache.maven.model.building.ModelBuildingException; import org.apache.maven.model.building.ModelBuildingRequest; @@ -394,14 +393,7 @@ public class MavenMetadataSource if ( !dependency.getExclusions().isEmpty() ) { - List<String> exclusions = new ArrayList<>(); - - for ( Exclusion e : dependency.getExclusions() ) - { - exclusions.add( e.getGroupId() + ':' + e.getArtifactId() ); - } - - effectiveFilter = new ExcludesArtifactFilter( exclusions ); + effectiveFilter = new ExclusionArtifactFilter( dependency.getExclusions() ); if ( inheritedFilter != null ) {