o Extended base plugin manager to allow for caller-supplied exclusions of certain plugin dependencies

git-svn-id: https://svn.apache.org/repos/asf/maven/maven-3/trunk@881793 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Benjamin Bentmann 2009-11-18 14:53:55 +00:00
parent 1068ab557c
commit 9e42487829
6 changed files with 47 additions and 24 deletions

View File

@ -182,7 +182,7 @@ public class DefaultBuildPluginManager
} }
mavenPluginManager.setupPluginRealm( pluginDescriptor, session, session.getCurrentProject().getClassRealm(), mavenPluginManager.setupPluginRealm( pluginDescriptor, session, session.getCurrentProject().getClassRealm(),
null ); null, null );
return pluginDescriptor.getClassRealm(); return pluginDescriptor.getClassRealm();
} }

View File

@ -28,6 +28,7 @@ import java.util.Map;
import org.apache.maven.artifact.Artifact; import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.repository.ArtifactRepository; import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.resolver.filter.ArtifactFilter;
import org.apache.maven.model.Dependency; import org.apache.maven.model.Dependency;
import org.apache.maven.model.Exclusion; import org.apache.maven.model.Exclusion;
import org.apache.maven.model.Plugin; import org.apache.maven.model.Plugin;
@ -53,9 +54,12 @@ public class DefaultPluginRealmCache
private final List<String> parentImports; private final List<String> parentImports;
private final ArtifactFilter filter;
private final int hashCode; private final int hashCode;
public CacheKey( Plugin plugin, ClassLoader parentRealm, List<String> parentImports, ArtifactRepository localRepository, public CacheKey( Plugin plugin, ClassLoader parentRealm, List<String> parentImports,
ArtifactFilter dependencyFilter, ArtifactRepository localRepository,
List<ArtifactRepository> remoteRepositories ) List<ArtifactRepository> remoteRepositories )
{ {
this.plugin = plugin.clone(); this.plugin = plugin.clone();
@ -63,12 +67,14 @@ public class DefaultPluginRealmCache
this.repositories.addAll( remoteRepositories ); this.repositories.addAll( remoteRepositories );
this.parentRealm = parentRealm; this.parentRealm = parentRealm;
this.parentImports = ( parentImports != null ) ? parentImports : Collections.<String> emptyList(); this.parentImports = ( parentImports != null ) ? parentImports : Collections.<String> emptyList();
this.filter = dependencyFilter;
int hash = 17; int hash = 17;
hash = hash * 31 + pluginHashCode( plugin ); hash = hash * 31 + pluginHashCode( plugin );
hash = hash * 31 + repositories.hashCode(); hash = hash * 31 + repositories.hashCode();
hash = hash * 31 + ( parentRealm != null ? parentRealm.hashCode() : 0 ); hash = hash * 31 + ( parentRealm != null ? parentRealm.hashCode() : 0 );
hash = hash * 31 + this.parentImports.hashCode(); hash = hash * 31 + this.parentImports.hashCode();
hash = hash * 31 + ( dependencyFilter != null ? dependencyFilter.hashCode() : 0 );
this.hashCode = hash; this.hashCode = hash;
} }
@ -94,19 +100,22 @@ public class DefaultPluginRealmCache
CacheKey other = (CacheKey) o; CacheKey other = (CacheKey) o;
return parentRealm == other.parentRealm && pluginEquals( plugin, other.plugin ) return parentRealm == other.parentRealm && pluginEquals( plugin, other.plugin )
&& eq( repositories, other.repositories ); && eq( repositories, other.repositories ) && eq( filter, other.filter )
&& eq( parentImports, other.parentImports );
} }
} }
protected final Map<CacheKey, CacheRecord> cache = new HashMap<CacheKey, CacheRecord>(); protected final Map<CacheKey, CacheRecord> cache = new HashMap<CacheKey, CacheRecord>();
public CacheRecord get( Plugin plugin, ClassLoader parentRealm, List<String> parentImports, public CacheRecord get( Plugin plugin, ClassLoader parentRealm, List<String> parentImports,
ArtifactRepository localRepository, List<ArtifactRepository> remoteRepositories ) ArtifactFilter dependencyFilter, ArtifactRepository localRepository,
List<ArtifactRepository> remoteRepositories )
{ {
return cache.get( new CacheKey( plugin, parentRealm, parentImports, localRepository, remoteRepositories ) ); return cache.get( new CacheKey( plugin, parentRealm, parentImports, dependencyFilter, localRepository,
remoteRepositories ) );
} }
public CacheRecord put( Plugin plugin, ClassLoader parentRealm, List<String> parentImports, public CacheRecord put( Plugin plugin, ClassLoader parentRealm, List<String> parentImports,ArtifactFilter dependencyFilter,
ArtifactRepository localRepository, List<ArtifactRepository> remoteRepositories, ArtifactRepository localRepository, List<ArtifactRepository> remoteRepositories,
ClassRealm pluginRealm, List<Artifact> pluginArtifacts ) ClassRealm pluginRealm, List<Artifact> pluginArtifacts )
{ {
@ -115,7 +124,8 @@ public class DefaultPluginRealmCache
throw new NullPointerException(); throw new NullPointerException();
} }
CacheKey key = new CacheKey( plugin, parentRealm, parentImports, localRepository, remoteRepositories ); CacheKey key =
new CacheKey( plugin, parentRealm, parentImports, dependencyFilter, localRepository, remoteRepositories );
if ( cache.containsKey( key ) ) if ( cache.containsKey( key ) )
{ {

View File

@ -22,6 +22,7 @@ package org.apache.maven.plugin;
import java.util.List; import java.util.List;
import org.apache.maven.artifact.repository.RepositoryRequest; import org.apache.maven.artifact.repository.RepositoryRequest;
import org.apache.maven.artifact.resolver.filter.ArtifactFilter;
import org.apache.maven.execution.MavenSession; import org.apache.maven.execution.MavenSession;
import org.apache.maven.model.Plugin; import org.apache.maven.model.Plugin;
import org.apache.maven.plugin.descriptor.MojoDescriptor; import org.apache.maven.plugin.descriptor.MojoDescriptor;
@ -71,9 +72,10 @@ public interface MavenPluginManager
* {@code null}. * {@code null}.
* @param parent The parent class realm for the plugin, may be {@code null} to use the Maven core realm. * @param parent The parent class realm for the plugin, may be {@code null} to use the Maven core realm.
* @param imports The packages/types to import from the parent realm, may be {@code null}. * @param imports The packages/types to import from the parent realm, may be {@code null}.
* @param filter The filter used to exclude certain plugin dependencies, may be {@code null}.
*/ */
void setupPluginRealm( PluginDescriptor pluginDescriptor, MavenSession session, ClassLoader parent, void setupPluginRealm( PluginDescriptor pluginDescriptor, MavenSession session, ClassLoader parent,
List<String> imports ) List<String> imports, ArtifactFilter filter )
throws PluginResolutionException, PluginContainerException; throws PluginResolutionException, PluginContainerException;
/** /**

View File

@ -23,6 +23,7 @@ import java.util.List;
import org.apache.maven.artifact.Artifact; import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.repository.ArtifactRepository; import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.resolver.filter.ArtifactFilter;
import org.apache.maven.model.Plugin; import org.apache.maven.model.Plugin;
import org.apache.maven.project.MavenProject; import org.apache.maven.project.MavenProject;
import org.codehaus.plexus.classworlds.realm.ClassRealm; import org.codehaus.plexus.classworlds.realm.ClassRealm;
@ -51,11 +52,12 @@ public interface PluginRealmCache
} }
CacheRecord get( Plugin plugin, ClassLoader parentRealm, List<String> parentImports, CacheRecord get( Plugin plugin, ClassLoader parentRealm, List<String> parentImports,
ArtifactRepository localRepository, List<ArtifactRepository> remoteRepositories ); ArtifactFilter dependencyFilter, ArtifactRepository localRepository,
List<ArtifactRepository> remoteRepositories );
CacheRecord put( Plugin plugin, ClassLoader parentRealm, List<String> parentImports, CacheRecord put( Plugin plugin, ClassLoader parentRealm, List<String> parentImports,
ArtifactRepository localRepository, List<ArtifactRepository> remoteRepositories, ArtifactFilter dependencyFilter, ArtifactRepository localRepository,
ClassRealm pluginRealm, List<Artifact> pluginArtifacts ); List<ArtifactRepository> remoteRepositories, ClassRealm pluginRealm, List<Artifact> pluginArtifacts );
void flush(); void flush();

View File

@ -290,7 +290,7 @@ public class DefaultMavenPluginManager
} }
public synchronized void setupPluginRealm( PluginDescriptor pluginDescriptor, MavenSession session, public synchronized void setupPluginRealm( PluginDescriptor pluginDescriptor, MavenSession session,
ClassLoader parent, List<String> imports ) ClassLoader parent, List<String> imports, ArtifactFilter filter )
throws PluginResolutionException, PluginContainerException throws PluginResolutionException, PluginContainerException
{ {
Plugin plugin = pluginDescriptor.getPlugin(); Plugin plugin = pluginDescriptor.getPlugin();
@ -298,7 +298,7 @@ public class DefaultMavenPluginManager
MavenProject project = session.getCurrentProject(); MavenProject project = session.getCurrentProject();
PluginRealmCache.CacheRecord cacheRecord = PluginRealmCache.CacheRecord cacheRecord =
pluginRealmCache.get( plugin, parent, imports, session.getLocalRepository(), pluginRealmCache.get( plugin, parent, imports, filter, session.getLocalRepository(),
project.getPluginArtifactRepositories() ); project.getPluginArtifactRepositories() );
if ( cacheRecord != null ) if ( cacheRecord != null )
@ -308,10 +308,10 @@ public class DefaultMavenPluginManager
} }
else else
{ {
createPluginRealm( pluginDescriptor, session, parent, imports ); createPluginRealm( pluginDescriptor, session, parent, imports, filter );
cacheRecord = cacheRecord =
pluginRealmCache.put( plugin, parent, imports, session.getLocalRepository(), pluginRealmCache.put( plugin, parent, imports, filter, session.getLocalRepository(),
project.getPluginArtifactRepositories(), pluginDescriptor.getClassRealm(), project.getPluginArtifactRepositories(), pluginDescriptor.getClassRealm(),
pluginDescriptor.getArtifacts() ); pluginDescriptor.getArtifacts() );
} }
@ -320,7 +320,7 @@ public class DefaultMavenPluginManager
} }
private void createPluginRealm( PluginDescriptor pluginDescriptor, MavenSession session, ClassLoader parent, private void createPluginRealm( PluginDescriptor pluginDescriptor, MavenSession session, ClassLoader parent,
List<String> imports ) List<String> imports, ArtifactFilter filter )
throws PluginResolutionException, PluginContainerException throws PluginResolutionException, PluginContainerException
{ {
Plugin plugin = pluginDescriptor.getPlugin(); Plugin plugin = pluginDescriptor.getPlugin();
@ -346,8 +346,17 @@ public class DefaultMavenPluginManager
request.setOffline( session.isOffline() ); request.setOffline( session.isOffline() );
request.setTransferListener( session.getRequest().getTransferListener() ); request.setTransferListener( session.getRequest().getTransferListener() );
List<Artifact> pluginArtifacts = ArtifactFilter dependencyFilter = project.getExtensionArtifactFilter();
resolvePluginArtifacts( plugin, pluginArtifact, request, project.getExtensionArtifactFilter() ); if ( dependencyFilter == null )
{
dependencyFilter = filter;
}
else if ( filter != null )
{
dependencyFilter = new AndArtifactFilter( Arrays.asList( dependencyFilter, filter ) );
}
List<Artifact> pluginArtifacts = resolvePluginArtifacts( plugin, pluginArtifact, request, dependencyFilter );
ClassRealm pluginRealm = classRealmManager.createPluginRealm( plugin, parent, imports ); ClassRealm pluginRealm = classRealmManager.createPluginRealm( plugin, parent, imports );
@ -420,7 +429,7 @@ public class DefaultMavenPluginManager
// FIXME: only exposed to allow workaround for MNG-4194 // FIXME: only exposed to allow workaround for MNG-4194
protected List<Artifact> resolvePluginArtifacts( Plugin plugin, Artifact pluginArtifact, protected List<Artifact> resolvePluginArtifacts( Plugin plugin, Artifact pluginArtifact,
RepositoryRequest repositoryRequest, RepositoryRequest repositoryRequest,
ArtifactFilter extensionArtifactFilter ) ArtifactFilter dependencyFilter )
throws PluginResolutionException throws PluginResolutionException
{ {
Set<Artifact> overrideArtifacts = new LinkedHashSet<Artifact>(); Set<Artifact> overrideArtifacts = new LinkedHashSet<Artifact>();
@ -433,9 +442,9 @@ public class DefaultMavenPluginManager
ArtifactFilter resolutionFilter = artifactFilterManager.getCoreArtifactFilter(); ArtifactFilter resolutionFilter = artifactFilterManager.getCoreArtifactFilter();
if ( extensionArtifactFilter != null ) if ( dependencyFilter != null )
{ {
resolutionFilter = new AndArtifactFilter( Arrays.asList( resolutionFilter, extensionArtifactFilter ) ); resolutionFilter = new AndArtifactFilter( Arrays.asList( resolutionFilter, dependencyFilter ) );
} }
ArtifactResolutionRequest request = new ArtifactResolutionRequest( repositoryRequest ); ArtifactResolutionRequest request = new ArtifactResolutionRequest( repositoryRequest );

View File

@ -119,7 +119,7 @@ public class DefaultPluginManager
pluginDescriptor = pluginManager.getPluginDescriptor( plugin, repositoryRequest ); pluginDescriptor = pluginManager.getPluginDescriptor( plugin, repositoryRequest );
pluginManager.setupPluginRealm( pluginDescriptor, session, null, null ); pluginManager.setupPluginRealm( pluginDescriptor, session, null, null, null );
} }
catch ( Exception e ) catch ( Exception e )
{ {
@ -151,7 +151,7 @@ public class DefaultPluginManager
pluginDescriptor = pluginManager.getPluginDescriptor( plugin, repositoryRequest ); pluginDescriptor = pluginManager.getPluginDescriptor( plugin, repositoryRequest );
pluginManager.setupPluginRealm( pluginDescriptor, session, null, null ); pluginManager.setupPluginRealm( pluginDescriptor, session, null, null, null );
} }
catch ( Exception e ) catch ( Exception e )
{ {
@ -231,7 +231,7 @@ public class DefaultPluginManager
try try
{ {
pluginManager.setupPluginRealm( pluginDescriptor, session, null, null ); pluginManager.setupPluginRealm( pluginDescriptor, session, null, null, null );
} }
catch ( PluginResolutionException e ) catch ( PluginResolutionException e )
{ {