You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@maven.apache.org by rf...@apache.org on 2015/05/18 23:01:40 UTC

svn commit: r1680097 - in /maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve: ./ internal/

Author: rfscholte
Date: Mon May 18 21:01:40 2015
New Revision: 1680097

URL: http://svn.apache.org/r1680097
Log:
Add resolveTransitively methods to ArtifactResolver + corresponding implementations

Modified:
    maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/ArtifactResolver.java
    maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/DefaultArtifactResolver.java
    maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven30ArtifactResolver.java
    maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven31ArtifactResolver.java

Modified: maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/ArtifactResolver.java
URL: http://svn.apache.org/viewvc/maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/ArtifactResolver.java?rev=1680097&r1=1680096&r2=1680097&view=diff
==============================================================================
--- maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/ArtifactResolver.java (original)
+++ maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/ArtifactResolver.java Mon May 18 21:01:40 2015
@@ -1,10 +1,5 @@
 package org.apache.maven.shared.artifact.resolve;
 
-import java.util.List;
-
-import org.apache.maven.artifact.repository.ArtifactRepository;
-import org.apache.maven.project.ProjectBuildingRequest;
-
 /*
  * Licensed to the Apache Software Foundation (ASF) under one
  * or more contributor license agreements.  See the NOTICE file
@@ -24,10 +19,29 @@ import org.apache.maven.project.ProjectB
  * under the License.
  */
 
+import java.util.List;
+
+import org.apache.maven.artifact.repository.ArtifactRepository;
+import org.apache.maven.project.ProjectBuildingRequest;
+import org.apache.maven.shared.artifact.resolve.filter.TransformableFilter;
+
 public interface ArtifactResolver
 {
+
     public org.apache.maven.artifact.Artifact resolveArtifact( ProjectBuildingRequest buildingRequest,
-                                 org.apache.maven.artifact.Artifact mavenArtifact, List<ArtifactRepository> remoteRepositories )
+                                                               org.apache.maven.artifact.Artifact mavenArtifact,
+                                                               List<ArtifactRepository> remoteRepositories )
+        throws ArtifactResolverException;
+
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest,
+                                     org.apache.maven.artifact.Artifact mavenArtifact,
+                                     List<ArtifactRepository> remoteRepositories )
+        throws ArtifactResolverException;
+    
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest,
+                                     org.apache.maven.artifact.Artifact mavenArtifact,
+                                     List<ArtifactRepository> remoteRepositories,
+                                     TransformableFilter filter )
         throws ArtifactResolverException;
 
 }

Modified: maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/DefaultArtifactResolver.java
URL: http://svn.apache.org/viewvc/maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/DefaultArtifactResolver.java?rev=1680097&r1=1680096&r2=1680097&view=diff
==============================================================================
--- maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/DefaultArtifactResolver.java (original)
+++ maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/DefaultArtifactResolver.java Mon May 18 21:01:40 2015
@@ -7,6 +7,7 @@ import org.apache.maven.artifact.reposit
 import org.apache.maven.project.ProjectBuildingRequest;
 import org.apache.maven.shared.artifact.resolve.ArtifactResolver;
 import org.apache.maven.shared.artifact.resolve.ArtifactResolverException;
+import org.apache.maven.shared.artifact.resolve.filter.TransformableFilter;
 import org.codehaus.plexus.PlexusConstants;
 import org.codehaus.plexus.PlexusContainer;
 import org.codehaus.plexus.component.annotations.Component;
@@ -58,7 +59,43 @@ public class DefaultArtifactResolver
             throw new ArtifactResolverException( e.getMessage(), e );
         }
     }
+    
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest, Artifact mavenArtifact,
+                                     List<ArtifactRepository> remoteRepositories )
+        throws ArtifactResolverException
+    {
+        try
+        {
+            String hint = isMaven31() ? "maven31" : "maven3";
+
+            ArtifactResolver effectiveArtifactResolver = container.lookup( ArtifactResolver.class, hint );
 
+            effectiveArtifactResolver.resolveTransitively( buildingRequest, mavenArtifact, remoteRepositories );
+        }
+        catch ( ComponentLookupException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+    }
+    
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest, Artifact mavenArtifact,
+                                     List<ArtifactRepository> remoteRepositories, TransformableFilter filter )
+        throws ArtifactResolverException
+    {
+        try
+        {
+            String hint = isMaven31() ? "maven31" : "maven3";
+
+            ArtifactResolver effectiveArtifactResolver = container.lookup( ArtifactResolver.class, hint );
+
+            effectiveArtifactResolver.resolveTransitively( buildingRequest, mavenArtifact, remoteRepositories, filter );
+        }
+        catch ( ComponentLookupException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+    }
+    
     /**
      * @return true if the current Maven version is Maven 3.1.
      */

Modified: maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven30ArtifactResolver.java
URL: http://svn.apache.org/viewvc/maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven30ArtifactResolver.java?rev=1680097&r1=1680096&r2=1680097&view=diff
==============================================================================
--- maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven30ArtifactResolver.java (original)
+++ maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven30ArtifactResolver.java Mon May 18 21:01:40 2015
@@ -19,6 +19,8 @@ package org.apache.maven.shared.artifact
  * under the License.
  */
 
+import java.util.ArrayList;
+import java.util.Collection;
 import java.util.List;
 
 import org.apache.maven.RepositoryUtils;
@@ -26,17 +28,22 @@ import org.apache.maven.artifact.reposit
 import org.apache.maven.project.ProjectBuildingRequest;
 import org.apache.maven.shared.artifact.resolve.ArtifactResolver;
 import org.apache.maven.shared.artifact.resolve.ArtifactResolverException;
+import org.apache.maven.shared.artifact.resolve.filter.TransformableFilter;
 import org.codehaus.plexus.component.annotations.Component;
 import org.codehaus.plexus.component.annotations.Requirement;
 import org.sonatype.aether.RepositorySystem;
 import org.sonatype.aether.RepositorySystemSession;
 import org.sonatype.aether.artifact.Artifact;
+import org.sonatype.aether.collection.CollectRequest;
+import org.sonatype.aether.collection.DependencyCollectionException;
+import org.sonatype.aether.graph.DependencyFilter;
 import org.sonatype.aether.repository.RemoteRepository;
 import org.sonatype.aether.resolution.ArtifactDescriptorException;
 import org.sonatype.aether.resolution.ArtifactDescriptorRequest;
 import org.sonatype.aether.resolution.ArtifactDescriptorResult;
 import org.sonatype.aether.resolution.ArtifactRequest;
 import org.sonatype.aether.resolution.ArtifactResolutionException;
+import org.sonatype.aether.resolution.ArtifactResult;
 
 @Component( role = ArtifactResolver.class, hint = "maven3" )
 public class Maven30ArtifactResolver
@@ -46,8 +53,8 @@ public class Maven30ArtifactResolver
     private RepositorySystem repositorySystem;
 
     public org.apache.maven.artifact.Artifact resolveArtifact( ProjectBuildingRequest buildingRequest,
-                                 org.apache.maven.artifact.Artifact mavenArtifact,
-                                 List<ArtifactRepository> remoteRepositories )
+                                                               org.apache.maven.artifact.Artifact mavenArtifact,
+                                                               List<ArtifactRepository> remoteRepositories )
         throws ArtifactResolverException
     {
         Artifact aetherArtifact =
@@ -56,23 +63,24 @@ public class Maven30ArtifactResolver
 
         @SuppressWarnings( "unchecked" )
         List<RemoteRepository> aetherRepositories =
-                        (List<RemoteRepository>) Invoker.invoke( RepositoryUtils.class, "toRepos",
-                                                                 List.class, remoteRepositories );
-        
+            (List<RemoteRepository>) Invoker.invoke( RepositoryUtils.class, "toRepos", List.class, remoteRepositories );
+
         RepositorySystemSession session =
             (RepositorySystemSession) Invoker.invoke( buildingRequest, "getRepositorySession" );
 
         try
         {
             // use descriptor to respect relocation
-            ArtifactDescriptorRequest descriptorRequest = new ArtifactDescriptorRequest( aetherArtifact, aetherRepositories, null );
-            
-            ArtifactDescriptorResult descriptorResult = repositorySystem.readArtifactDescriptor( session, descriptorRequest );
-            
+            ArtifactDescriptorRequest descriptorRequest =
+                new ArtifactDescriptorRequest( aetherArtifact, aetherRepositories, null );
+
+            ArtifactDescriptorResult descriptorResult =
+                repositorySystem.readArtifactDescriptor( session, descriptorRequest );
+
             ArtifactRequest request = new ArtifactRequest( descriptorResult.getArtifact(), aetherRepositories, null );
-            
+
             Artifact resolvedArtifact = repositorySystem.resolveArtifact( session, request ).getArtifact();
-            
+
             return (org.apache.maven.artifact.Artifact) Invoker.invoke( RepositoryUtils.class, "toArtifact",
                                                                         Artifact.class, resolvedArtifact );
         }
@@ -86,4 +94,74 @@ public class Maven30ArtifactResolver
         }
     }
 
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest,
+                                  org.apache.maven.artifact.Artifact mavenArtifact,
+                                  List<ArtifactRepository> remoteRepositories )
+        throws ArtifactResolverException
+    {
+        resolveTransitively( buildingRequest, mavenArtifact, remoteRepositories, null );
+    }
+
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest,
+                                  org.apache.maven.artifact.Artifact mavenArtifact,
+                                  List<ArtifactRepository> remoteRepositories,
+                                  TransformableFilter dependencyFilter )
+        throws ArtifactResolverException
+    {
+        Artifact aetherArtifact =
+            (Artifact) Invoker.invoke( RepositoryUtils.class, "toArtifact", org.apache.maven.artifact.Artifact.class,
+                                       mavenArtifact );
+
+        @SuppressWarnings( "unchecked" )
+        List<RemoteRepository> aetherRepositories =
+            (List<RemoteRepository>) Invoker.invoke( RepositoryUtils.class, "toRepos", List.class, remoteRepositories );
+
+        RepositorySystemSession session =
+            (RepositorySystemSession) Invoker.invoke( buildingRequest, "getRepositorySession" );
+
+        try
+        {
+            // use descriptor to respect relocation
+            ArtifactDescriptorRequest descriptorRequest =
+                new ArtifactDescriptorRequest( aetherArtifact, aetherRepositories, null );
+
+            ArtifactDescriptorResult descriptorResult =
+                repositorySystem.readArtifactDescriptor( session, descriptorRequest );
+
+            CollectRequest request =
+                new CollectRequest( descriptorResult.getDependencies(), descriptorResult.getManagedDependencies(),
+                                    aetherRepositories );
+
+            DependencyFilter depFilter  = null;
+            if( dependencyFilter != null )
+            {
+                depFilter = dependencyFilter.transform( new SonatypeAetherFilterTransformer() );
+            }
+
+            List<ArtifactResult> artifactResults = repositorySystem.resolveDependencies( session, request, depFilter );
+
+            Collection<ArtifactRequest> artifactRequests = new ArrayList<ArtifactRequest>( 1 + artifactResults.size() );
+
+            artifactRequests.add( new ArtifactRequest( descriptorResult.getArtifact(), aetherRepositories, null ) );
+
+            for ( ArtifactResult artifactResult : artifactResults )
+            {
+                artifactRequests.add( new ArtifactRequest( artifactResult.getArtifact(), aetherRepositories, null ) );
+            }
+
+            repositorySystem.resolveArtifacts( session, artifactRequests );
+        }
+        catch ( ArtifactDescriptorException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+        catch ( ArtifactResolutionException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+        catch ( DependencyCollectionException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+    }
 }

Modified: maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven31ArtifactResolver.java
URL: http://svn.apache.org/viewvc/maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven31ArtifactResolver.java?rev=1680097&r1=1680096&r2=1680097&view=diff
==============================================================================
--- maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven31ArtifactResolver.java (original)
+++ maven/shared/trunk/maven-artifact-transfer/src/main/java/org/apache/maven/shared/artifact/resolve/internal/Maven31ArtifactResolver.java Mon May 18 21:01:40 2015
@@ -19,6 +19,8 @@ package org.apache.maven.shared.artifact
  * under the License.
  */
 
+import java.util.ArrayList;
+import java.util.Collection;
 import java.util.List;
 
 import org.apache.maven.RepositoryUtils;
@@ -26,17 +28,23 @@ import org.apache.maven.artifact.reposit
 import org.apache.maven.project.ProjectBuildingRequest;
 import org.apache.maven.shared.artifact.resolve.ArtifactResolver;
 import org.apache.maven.shared.artifact.resolve.ArtifactResolverException;
+import org.apache.maven.shared.artifact.resolve.filter.TransformableFilter;
 import org.codehaus.plexus.component.annotations.Component;
 import org.codehaus.plexus.component.annotations.Requirement;
 import org.eclipse.aether.RepositorySystem;
 import org.eclipse.aether.RepositorySystemSession;
 import org.eclipse.aether.artifact.Artifact;
+import org.eclipse.aether.collection.CollectRequest;
+import org.eclipse.aether.graph.DependencyFilter;
 import org.eclipse.aether.repository.RemoteRepository;
 import org.eclipse.aether.resolution.ArtifactDescriptorException;
 import org.eclipse.aether.resolution.ArtifactDescriptorRequest;
 import org.eclipse.aether.resolution.ArtifactDescriptorResult;
 import org.eclipse.aether.resolution.ArtifactRequest;
 import org.eclipse.aether.resolution.ArtifactResolutionException;
+import org.eclipse.aether.resolution.ArtifactResult;
+import org.eclipse.aether.resolution.DependencyRequest;
+import org.eclipse.aether.resolution.DependencyResolutionException;
 
 @Component( role = ArtifactResolver.class, hint = "maven31" )
 public class Maven31ArtifactResolver
@@ -46,8 +54,8 @@ public class Maven31ArtifactResolver
     private RepositorySystem repositorySystem;
 
     public org.apache.maven.artifact.Artifact resolveArtifact( ProjectBuildingRequest buildingRequest,
-                                 org.apache.maven.artifact.Artifact mavenArtifact,
-                                 List<ArtifactRepository> remoteRepositories )
+                                                               org.apache.maven.artifact.Artifact mavenArtifact,
+                                                               List<ArtifactRepository> remoteRepositories )
         throws ArtifactResolverException
     {
         Artifact aetherArtifact =
@@ -56,8 +64,7 @@ public class Maven31ArtifactResolver
 
         @SuppressWarnings( "unchecked" )
         List<RemoteRepository> aetherRepositories =
-            (List<RemoteRepository>) Invoker.invoke( RepositoryUtils.class, "toRepos",
-                                                     List.class, remoteRepositories );        
+            (List<RemoteRepository>) Invoker.invoke( RepositoryUtils.class, "toRepos", List.class, remoteRepositories );
 
         RepositorySystemSession session =
             (RepositorySystemSession) Invoker.invoke( buildingRequest, "getRepositorySession" );
@@ -65,14 +72,16 @@ public class Maven31ArtifactResolver
         try
         {
             // use descriptor to respect relocation
-            ArtifactDescriptorRequest descriptorRequest = new ArtifactDescriptorRequest( aetherArtifact, aetherRepositories, null );
-            
-            ArtifactDescriptorResult descriptorResult = repositorySystem.readArtifactDescriptor( session, descriptorRequest );
+            ArtifactDescriptorRequest descriptorRequest =
+                new ArtifactDescriptorRequest( aetherArtifact, aetherRepositories, null );
+
+            ArtifactDescriptorResult descriptorResult =
+                repositorySystem.readArtifactDescriptor( session, descriptorRequest );
 
             ArtifactRequest request = new ArtifactRequest( descriptorResult.getArtifact(), aetherRepositories, null );
-            
+
             Artifact resolvedArtifact = repositorySystem.resolveArtifact( session, request ).getArtifact();
-            
+
             return (org.apache.maven.artifact.Artifact) Invoker.invoke( RepositoryUtils.class, "toArtifact",
                                                                         Artifact.class, resolvedArtifact );
         }
@@ -86,4 +95,76 @@ public class Maven31ArtifactResolver
         }
     }
 
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest,
+                                     org.apache.maven.artifact.Artifact mavenArtifact,
+                                     List<ArtifactRepository> remoteRepositories )
+        throws ArtifactResolverException
+    {
+        resolveTransitively( buildingRequest, mavenArtifact, remoteRepositories, null );
+    }
+
+    public void resolveTransitively( ProjectBuildingRequest buildingRequest,
+                                     org.apache.maven.artifact.Artifact mavenArtifact,
+                                     List<ArtifactRepository> remoteRepositories, TransformableFilter dependencyFilter )
+        throws ArtifactResolverException
+    {
+        Artifact aetherArtifact =
+            (Artifact) Invoker.invoke( RepositoryUtils.class, "toArtifact", org.apache.maven.artifact.Artifact.class,
+                                       mavenArtifact );
+
+        @SuppressWarnings( "unchecked" )
+        List<RemoteRepository> aetherRepositories =
+            (List<RemoteRepository>) Invoker.invoke( RepositoryUtils.class, "toRepos", List.class, remoteRepositories );
+
+        RepositorySystemSession session =
+            (RepositorySystemSession) Invoker.invoke( buildingRequest, "getRepositorySession" );
+
+        try
+        {
+            // use descriptor to respect relocation
+            ArtifactDescriptorRequest descriptorRequest =
+                new ArtifactDescriptorRequest( aetherArtifact, aetherRepositories, null );
+
+            ArtifactDescriptorResult descriptorResult =
+                repositorySystem.readArtifactDescriptor( session, descriptorRequest );
+
+            CollectRequest request =
+                new CollectRequest( descriptorResult.getDependencies(), descriptorResult.getManagedDependencies(),
+                                    aetherRepositories );
+
+            DependencyFilter depFilter = null;
+            if ( dependencyFilter != null )
+            {
+                depFilter = dependencyFilter.transform( new EclipseAetherFilterTransformer() );
+            }
+
+            DependencyRequest depRequest = new DependencyRequest( request, depFilter );
+
+            List<ArtifactResult> artifactResults =
+                repositorySystem.resolveDependencies( session, depRequest ).getArtifactResults();
+
+            Collection<ArtifactRequest> artifactRequests = new ArrayList<ArtifactRequest>( 1 + artifactResults.size() );
+
+            artifactRequests.add( new ArtifactRequest( descriptorResult.getArtifact(), aetherRepositories, null ) );
+
+            for ( ArtifactResult artifactResult : artifactResults )
+            {
+                artifactRequests.add( new ArtifactRequest( artifactResult.getArtifact(), aetherRepositories, null ) );
+            }
+
+            repositorySystem.resolveArtifacts( session, artifactRequests );
+        }
+        catch ( ArtifactDescriptorException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+        catch ( ArtifactResolutionException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+        catch ( DependencyResolutionException e )
+        {
+            throw new ArtifactResolverException( e.getMessage(), e );
+        }
+    }
 }