mirror of https://github.com/apache/maven.git
o Fixed CLI invovations of plugins with project-level plugin dependencies
git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@784452 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e743f23a6a
commit
ef1445e0d8
|
@ -39,6 +39,7 @@ import org.apache.maven.artifact.resolver.ArtifactNotFoundException;
|
||||||
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
|
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
|
||||||
import org.apache.maven.execution.MavenSession;
|
import org.apache.maven.execution.MavenSession;
|
||||||
import org.apache.maven.lifecycle.mapping.LifecycleMapping;
|
import org.apache.maven.lifecycle.mapping.LifecycleMapping;
|
||||||
|
import org.apache.maven.model.Dependency;
|
||||||
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.CycleDetectedInPluginGraphException;
|
import org.apache.maven.plugin.CycleDetectedInPluginGraphException;
|
||||||
|
@ -642,12 +643,10 @@ public class DefaultLifecycleExecutor
|
||||||
plugin = findPluginForPrefix( prefix, session );
|
plugin = findPluginForPrefix( prefix, session );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
injectPluginDeclarationFromProject( plugin, project );
|
||||||
|
|
||||||
if ( plugin.getVersion() == null )
|
if ( plugin.getVersion() == null )
|
||||||
{
|
{
|
||||||
// We need to get it from the POM first before anything else
|
|
||||||
//
|
|
||||||
plugin.setVersion( attemptToGetPluginVersionFromProject( plugin, project ) );
|
|
||||||
|
|
||||||
// If there is no version to be found then we need to look in the repository metadata for
|
// If there is no version to be found then we need to look in the repository metadata for
|
||||||
// this plugin and see what's specified as the latest release.
|
// this plugin and see what's specified as the latest release.
|
||||||
//
|
//
|
||||||
|
@ -736,27 +735,35 @@ public class DefaultLifecycleExecutor
|
||||||
return pluginManager.getMojoDescriptor( plugin, goal, session.getLocalRepository(), project.getPluginArtifactRepositories() );
|
return pluginManager.getMojoDescriptor( plugin, goal, session.getLocalRepository(), project.getPluginArtifactRepositories() );
|
||||||
}
|
}
|
||||||
|
|
||||||
private String attemptToGetPluginVersionFromProject( Plugin plugin, MavenProject project )
|
private void injectPluginDeclarationFromProject( Plugin plugin, MavenProject project )
|
||||||
{
|
{
|
||||||
for ( Plugin pluginInPom : project.getBuildPlugins() )
|
Plugin pluginInPom = findPlugin( plugin, project.getBuildPlugins() );
|
||||||
|
|
||||||
|
if ( pluginInPom == null && project.getPluginManagement() != null )
|
||||||
{
|
{
|
||||||
if ( pluginInPom.getArtifactId().equals( plugin.getArtifactId() ) )
|
pluginInPom = findPlugin( plugin, project.getPluginManagement().getPlugins() );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( pluginInPom != null )
|
||||||
{
|
{
|
||||||
return pluginInPom.getVersion();
|
if ( plugin.getVersion() == null )
|
||||||
|
{
|
||||||
|
plugin.setVersion( pluginInPom.getVersion() );
|
||||||
|
}
|
||||||
|
|
||||||
|
plugin.setDependencies( new ArrayList<Dependency>( pluginInPom.getDependencies() ) );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( plugin.getVersion() == null && project.getPluginManagement() != null )
|
private Plugin findPlugin( Plugin plugin, Collection<Plugin> plugins )
|
||||||
{
|
{
|
||||||
for ( Plugin pluginInPom : project.getPluginManagement().getPlugins() )
|
for ( Plugin p : plugins )
|
||||||
{
|
{
|
||||||
if ( pluginInPom.getArtifactId().equals( plugin.getArtifactId() ) )
|
if ( p.getKey().equals( plugin.getKey() ) )
|
||||||
{
|
{
|
||||||
return pluginInPom.getVersion();
|
return p;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue