o getting the project dependencies now does not require two passes and we now always resolve from the root artifact. we no longer have to set the dependency artifacts either. with chained local repositories everything will be found in a repository so you don't have to make a distinction between what you have in a reactor/workspace/repo. the artifact will be found.

git-svn-id: https://svn.apache.org/repos/asf/maven/components/branches/MNG-2766@774078 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Jason van Zyl 2009-05-12 20:50:04 +00:00
parent 06a7b6abec
commit b6ee917be9
1 changed files with 23 additions and 38 deletions

View File

@ -41,9 +41,6 @@ import org.apache.maven.lifecycle.mapping.LifecycleMapping;
import org.apache.maven.model.Plugin; import org.apache.maven.model.Plugin;
import org.apache.maven.model.PluginExecution; import org.apache.maven.model.PluginExecution;
import org.apache.maven.plugin.MojoExecution; import org.apache.maven.plugin.MojoExecution;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugin.PluginConfigurationException;
import org.apache.maven.plugin.PluginExecutionException;
import org.apache.maven.plugin.PluginLoaderException; import org.apache.maven.plugin.PluginLoaderException;
import org.apache.maven.plugin.PluginManager; import org.apache.maven.plugin.PluginManager;
import org.apache.maven.plugin.PluginParameterExpressionEvaluator; import org.apache.maven.plugin.PluginParameterExpressionEvaluator;
@ -101,7 +98,6 @@ public class DefaultLifecycleExecutor
private Map<String, Lifecycle> phaseToLifecycleMap; private Map<String, Lifecycle> phaseToLifecycleMap;
public void execute( MavenSession session ) public void execute( MavenSession session )
throws LifecycleExecutionException, MojoFailureException
{ {
logger.info( "Build Order:" ); logger.info( "Build Order:" );
logger.info( "" ); logger.info( "" );
@ -125,11 +121,6 @@ public class DefaultLifecycleExecutor
} }
} }
if ( goals.isEmpty() )
{
throw new LifecycleExecutionException( "\n\nYou must specify at least one goal. Try 'mvn install' to build or 'mvn --help' for options \nSee http://maven.apache.org for more information.\n\n" );
}
for ( MavenProject currentProject : session.getProjects() ) for ( MavenProject currentProject : session.getProjects() )
{ {
logger.info( "Building " + currentProject.getName() ); logger.info( "Building " + currentProject.getName() );
@ -140,7 +131,17 @@ public class DefaultLifecycleExecutor
for ( String goal : goals ) for ( String goal : goals )
{ {
List<MojoExecution> lifecyclePlan = calculateLifecyclePlan( goal, session ); List<MojoExecution> lifecyclePlan;
try
{
lifecyclePlan = calculateLifecyclePlan( goal, session );
}
catch ( LifecycleExecutionException e )
{
session.getResult().addException( e );
return;
}
//TODO: once we have calculated the build plan then we should accurately be able to download //TODO: once we have calculated the build plan then we should accurately be able to download
// the project dependencies. Having it happen in the plugin manager is a tangled mess. We can optimize this // the project dependencies. Having it happen in the plugin manager is a tangled mess. We can optimize this
@ -153,9 +154,13 @@ public class DefaultLifecycleExecutor
} }
catch ( ArtifactResolutionException e ) catch ( ArtifactResolutionException e )
{ {
session.getResult().addException( e );
return;
} }
catch ( ArtifactNotFoundException e ) catch ( ArtifactNotFoundException e )
{ {
session.getResult().addException( e );
return;
} }
if ( logger.isDebugEnabled() ) if ( logger.isDebugEnabled() )
@ -182,15 +187,10 @@ public class DefaultLifecycleExecutor
logger.info( executionDescription( mojoExecution, currentProject ) ); logger.info( executionDescription( mojoExecution, currentProject ) );
pluginManager.executeMojo( session, mojoExecution ); pluginManager.executeMojo( session, mojoExecution );
} }
catch ( PluginExecutionException e ) catch ( Exception e )
{ {
// This looks like a duplicate session.getResult().addException( e );
throw new LifecycleExecutionException( "Error executing goal.", e ); return;
}
catch ( PluginConfigurationException e )
{
// If the mojo can't actually be configured
throw new LifecycleExecutionException( "Error executing goal.", e );
} }
} }
} }
@ -949,8 +949,6 @@ public class DefaultLifecycleExecutor
*/ */
// This can ultimately be moved up to the Maven component
private void downloadProjectDependencies( MavenSession session, String scope ) private void downloadProjectDependencies( MavenSession session, String scope )
throws ArtifactResolutionException, ArtifactNotFoundException throws ArtifactResolutionException, ArtifactNotFoundException
{ {
@ -960,29 +958,16 @@ public class DefaultLifecycleExecutor
ArtifactFilter filter = new ScopeArtifactFilter( scope ); ArtifactFilter filter = new ScopeArtifactFilter( scope );
ArtifactResolutionRequest request = new ArtifactResolutionRequest().setArtifact( artifact ) ArtifactResolutionRequest request = new ArtifactResolutionRequest()
// Here the root is not resolved because we are presumably working with a project locally. .setArtifact( artifact )
.setResolveRoot( false )
.setResolveTransitively( true ) .setResolveTransitively( true )
//.setArtifactDependencies( project.getDependencyArtifacts() )
.setLocalRepository( session.getLocalRepository() ) .setLocalRepository( session.getLocalRepository() )
.setRemoteRepostories( project.getRemoteArtifactRepositories() ) .setRemoteRepostories( project.getRemoteArtifactRepositories() )
.setManagedVersionMap( project.getManagedVersionMap() ) .setManagedVersionMap( project.getManagedVersionMap() )
.setFilter( filter ); .setFilter( filter );
ArtifactResolutionResult result = repositorySystem.resolve( request ); ArtifactResolutionResult result = repositorySystem.resolve( request );
resolutionErrorHandler.throwErrors( request, result ); resolutionErrorHandler.throwErrors( request, result );
//TODO: this is wrong
project.setArtifacts( result.getArtifacts() ); project.setArtifacts( result.getArtifacts() );
ArtifactRepository localRepository = session.getLocalRepository();
List<ArtifactRepository> remoteArtifactRepositories = session.getCurrentProject().getRemoteArtifactRepositories();
for ( Artifact projectArtifact : session.getCurrentProject().getArtifacts() )
{
repositorySystem.resolve( new ArtifactResolutionRequest( projectArtifact, localRepository, remoteArtifactRepositories ) );
}
} }
} }