1 | |
package org.apache.maven.plugin; |
2 | |
|
3 | |
|
4 | |
|
5 | |
|
6 | |
|
7 | |
|
8 | |
|
9 | |
|
10 | |
|
11 | |
|
12 | |
|
13 | |
|
14 | |
|
15 | |
|
16 | |
|
17 | |
|
18 | |
|
19 | |
|
20 | |
|
21 | |
|
22 | |
import static org.apache.maven.container.ContainerUtils.findChildComponentHints; |
23 | |
|
24 | |
import org.apache.maven.MavenArtifactFilterManager; |
25 | |
import org.apache.maven.artifact.Artifact; |
26 | |
import org.apache.maven.artifact.factory.ArtifactFactory; |
27 | |
import org.apache.maven.artifact.metadata.ArtifactMetadataRetrievalException; |
28 | |
import org.apache.maven.artifact.metadata.ArtifactMetadataSource; |
29 | |
import org.apache.maven.artifact.metadata.ResolutionGroup; |
30 | |
import org.apache.maven.artifact.repository.ArtifactRepository; |
31 | |
import org.apache.maven.artifact.resolver.ArtifactNotFoundException; |
32 | |
import org.apache.maven.artifact.resolver.ArtifactResolutionException; |
33 | |
import org.apache.maven.artifact.resolver.ArtifactResolutionResult; |
34 | |
import org.apache.maven.artifact.resolver.ArtifactResolver; |
35 | |
import org.apache.maven.artifact.resolver.MultipleArtifactsNotFoundException; |
36 | |
import org.apache.maven.artifact.resolver.filter.ArtifactFilter; |
37 | |
import org.apache.maven.artifact.resolver.filter.ScopeArtifactFilter; |
38 | |
import org.apache.maven.artifact.versioning.DefaultArtifactVersion; |
39 | |
import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException; |
40 | |
import org.apache.maven.artifact.versioning.VersionRange; |
41 | |
import org.apache.maven.execution.MavenSession; |
42 | |
import org.apache.maven.execution.RuntimeInformation; |
43 | |
import org.apache.maven.model.Plugin; |
44 | |
import org.apache.maven.model.ReportPlugin; |
45 | |
import org.apache.maven.monitor.event.EventDispatcher; |
46 | |
import org.apache.maven.monitor.event.MavenEvents; |
47 | |
import org.apache.maven.monitor.logging.DefaultLog; |
48 | |
import org.apache.maven.plugin.descriptor.MojoDescriptor; |
49 | |
import org.apache.maven.plugin.descriptor.Parameter; |
50 | |
import org.apache.maven.plugin.descriptor.PluginDescriptor; |
51 | |
import org.apache.maven.plugin.descriptor.PluginDescriptorBuilder; |
52 | |
import org.apache.maven.plugin.logging.Log; |
53 | |
import org.apache.maven.plugin.version.PluginVersionManager; |
54 | |
import org.apache.maven.plugin.version.PluginVersionNotFoundException; |
55 | |
import org.apache.maven.plugin.version.PluginVersionResolutionException; |
56 | |
import org.apache.maven.project.MavenProject; |
57 | |
import org.apache.maven.project.MavenProjectBuilder; |
58 | |
import org.apache.maven.project.ProjectBuildingException; |
59 | |
import org.apache.maven.project.artifact.InvalidDependencyVersionException; |
60 | |
import org.apache.maven.project.artifact.MavenMetadataSource; |
61 | |
import org.apache.maven.project.path.PathTranslator; |
62 | |
import org.apache.maven.reporting.MavenReport; |
63 | |
import org.apache.maven.settings.Settings; |
64 | |
import org.apache.maven.wagon.Wagon; |
65 | |
import org.codehaus.classworlds.ClassRealm; |
66 | |
import org.codehaus.classworlds.NoSuchRealmException; |
67 | |
import org.codehaus.plexus.PlexusConstants; |
68 | |
import org.codehaus.plexus.PlexusContainer; |
69 | |
import org.codehaus.plexus.PlexusContainerException; |
70 | |
import org.codehaus.plexus.component.configurator.ComponentConfigurationException; |
71 | |
import org.codehaus.plexus.component.configurator.ComponentConfigurator; |
72 | |
import org.codehaus.plexus.component.configurator.ConfigurationListener; |
73 | |
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluationException; |
74 | |
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluator; |
75 | |
import org.codehaus.plexus.component.discovery.ComponentDiscoveryListener; |
76 | |
import org.codehaus.plexus.component.repository.ComponentDescriptor; |
77 | |
import org.codehaus.plexus.component.repository.exception.ComponentLifecycleException; |
78 | |
import org.codehaus.plexus.component.repository.exception.ComponentLookupException; |
79 | |
import org.codehaus.plexus.configuration.PlexusConfiguration; |
80 | |
import org.codehaus.plexus.configuration.xml.XmlPlexusConfiguration; |
81 | |
import org.codehaus.plexus.context.Context; |
82 | |
import org.codehaus.plexus.context.ContextException; |
83 | |
import org.codehaus.plexus.logging.AbstractLogEnabled; |
84 | |
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable; |
85 | |
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Initializable; |
86 | |
import org.codehaus.plexus.util.StringUtils; |
87 | |
import org.codehaus.plexus.util.xml.Xpp3Dom; |
88 | |
|
89 | |
import java.io.File; |
90 | |
import java.net.URL; |
91 | |
import java.util.ArrayList; |
92 | |
import java.util.Arrays; |
93 | |
import java.util.Collection; |
94 | |
import java.util.Collections; |
95 | |
import java.util.HashMap; |
96 | |
import java.util.HashSet; |
97 | |
import java.util.Iterator; |
98 | |
import java.util.LinkedHashMap; |
99 | |
import java.util.LinkedHashSet; |
100 | |
import java.util.List; |
101 | |
import java.util.Map; |
102 | |
import java.util.Set; |
103 | |
|
104 | |
public class DefaultPluginManager |
105 | |
extends AbstractLogEnabled |
106 | |
implements PluginManager, Initializable, Contextualizable |
107 | |
{ |
108 | |
protected PlexusContainer container; |
109 | |
|
110 | |
protected PluginDescriptorBuilder pluginDescriptorBuilder; |
111 | |
|
112 | |
protected ArtifactFilter artifactFilter; |
113 | |
|
114 | |
private Log mojoLogger; |
115 | |
|
116 | 0 | private Map resolvedCoreArtifactFiles = new HashMap(); |
117 | |
|
118 | |
|
119 | |
protected PathTranslator pathTranslator; |
120 | |
|
121 | |
protected MavenPluginCollector pluginCollector; |
122 | |
|
123 | |
protected PluginVersionManager pluginVersionManager; |
124 | |
|
125 | |
protected ArtifactFactory artifactFactory; |
126 | |
|
127 | |
protected ArtifactResolver artifactResolver; |
128 | |
|
129 | |
protected ArtifactMetadataSource artifactMetadataSource; |
130 | |
|
131 | |
protected RuntimeInformation runtimeInformation; |
132 | |
|
133 | |
protected MavenProjectBuilder mavenProjectBuilder; |
134 | |
|
135 | |
protected PluginMappingManager pluginMappingManager; |
136 | |
|
137 | |
|
138 | |
|
139 | |
public DefaultPluginManager() |
140 | 0 | { |
141 | 0 | pluginDescriptorBuilder = new PluginDescriptorBuilder(); |
142 | 0 | } |
143 | |
|
144 | |
|
145 | |
|
146 | |
|
147 | |
|
148 | |
public PluginDescriptor getPluginDescriptorForPrefix( String prefix ) |
149 | |
{ |
150 | 0 | return pluginCollector.getPluginDescriptorForPrefix( prefix ); |
151 | |
} |
152 | |
|
153 | |
public Plugin getPluginDefinitionForPrefix( String prefix, |
154 | |
MavenSession session, |
155 | |
MavenProject project ) |
156 | |
{ |
157 | |
|
158 | |
|
159 | 0 | return pluginMappingManager.getByPrefix( prefix, session.getSettings().getPluginGroups(), |
160 | |
project.getPluginArtifactRepositories(), |
161 | |
session.getLocalRepository() ); |
162 | |
} |
163 | |
|
164 | |
|
165 | |
|
166 | |
|
167 | |
public PluginDescriptor verifyPlugin( Plugin plugin, |
168 | |
MavenProject project, |
169 | |
Settings settings, |
170 | |
ArtifactRepository localRepository ) |
171 | |
throws ArtifactResolutionException, PluginVersionResolutionException, ArtifactNotFoundException, |
172 | |
InvalidVersionSpecificationException, InvalidPluginException, PluginManagerException, PluginNotFoundException, |
173 | |
PluginVersionNotFoundException |
174 | |
{ |
175 | |
|
176 | |
|
177 | 0 | if ( plugin.getVersion() == null ) |
178 | |
{ |
179 | 0 | String version = pluginVersionManager.resolvePluginVersion( plugin.getGroupId(), plugin.getArtifactId(), |
180 | |
project, settings, localRepository ); |
181 | 0 | plugin.setVersion( version ); |
182 | |
} |
183 | |
|
184 | 0 | return verifyVersionedPlugin( plugin, project, localRepository ); |
185 | |
} |
186 | |
|
187 | |
private PluginDescriptor verifyVersionedPlugin( Plugin plugin, |
188 | |
MavenProject project, |
189 | |
ArtifactRepository localRepository ) |
190 | |
throws PluginVersionResolutionException, ArtifactNotFoundException, ArtifactResolutionException, |
191 | |
InvalidVersionSpecificationException, InvalidPluginException, PluginManagerException, PluginNotFoundException |
192 | |
{ |
193 | |
|
194 | |
|
195 | |
|
196 | |
|
197 | |
try |
198 | |
{ |
199 | 0 | VersionRange versionRange = VersionRange.createFromVersionSpec( plugin.getVersion() ); |
200 | |
|
201 | 0 | List remoteRepositories = new ArrayList(); |
202 | 0 | remoteRepositories.addAll( project.getPluginArtifactRepositories() ); |
203 | 0 | remoteRepositories.addAll( project.getRemoteArtifactRepositories() ); |
204 | |
|
205 | 0 | checkRequiredMavenVersion( plugin, localRepository, remoteRepositories ); |
206 | |
|
207 | 0 | Artifact pluginArtifact = |
208 | |
artifactFactory.createPluginArtifact( plugin.getGroupId(), plugin.getArtifactId(), versionRange ); |
209 | |
|
210 | 0 | pluginArtifact = project.replaceWithActiveArtifact( pluginArtifact ); |
211 | |
|
212 | 0 | artifactResolver.resolve( pluginArtifact, project.getPluginArtifactRepositories(), localRepository ); |
213 | |
|
214 | 0 | plugin.setVersion( pluginArtifact.getBaseVersion() ); |
215 | |
|
216 | 0 | String pluginKey = PluginUtils.constructVersionedKey( plugin ); |
217 | |
|
218 | 0 | PlexusContainer pluginContainer = container.getChildContainer( pluginKey ); |
219 | |
|
220 | 0 | File pluginFile = pluginArtifact.getFile(); |
221 | |
|
222 | 0 | if ( !pluginCollector.isPluginInstalled( plugin ) || ( pluginContainer == null ) ) |
223 | |
{ |
224 | 0 | addPlugin( plugin, pluginArtifact, project, localRepository ); |
225 | |
} |
226 | 0 | else if ( pluginFile.lastModified() > pluginContainer.getCreationDate().getTime() ) |
227 | |
{ |
228 | 0 | getLogger().info( |
229 | |
"Reloading plugin container for: " + pluginKey + ". The plugin artifact has changed." ); |
230 | |
|
231 | 0 | pluginContainer.dispose(); |
232 | |
|
233 | 0 | pluginCollector.flushPluginDescriptor( plugin ); |
234 | |
|
235 | 0 | addPlugin( plugin, pluginArtifact, project, localRepository ); |
236 | |
} |
237 | |
|
238 | 0 | project.addPlugin( plugin ); |
239 | |
} |
240 | 0 | catch ( ArtifactNotFoundException e ) |
241 | |
{ |
242 | 0 | String groupId = plugin.getGroupId(); |
243 | 0 | String artifactId = plugin.getArtifactId(); |
244 | 0 | String version = plugin.getVersion(); |
245 | |
|
246 | 0 | if ( ( groupId == null ) || ( artifactId == null ) || ( version == null ) ) |
247 | |
{ |
248 | 0 | throw new PluginNotFoundException( e ); |
249 | |
} |
250 | 0 | else if ( groupId.equals( e.getGroupId() ) && artifactId.equals( e.getArtifactId() ) && |
251 | |
version.equals( e.getVersion() ) && "maven-plugin".equals( e.getType() ) ) |
252 | |
{ |
253 | 0 | throw new PluginNotFoundException( e ); |
254 | |
} |
255 | |
else |
256 | |
{ |
257 | 0 | throw e; |
258 | |
} |
259 | 0 | } |
260 | |
|
261 | 0 | return pluginCollector.getPluginDescriptor( plugin ); |
262 | |
} |
263 | |
|
264 | |
|
265 | |
|
266 | |
|
267 | |
|
268 | |
private void checkRequiredMavenVersion( Plugin plugin, |
269 | |
ArtifactRepository localRepository, |
270 | |
List remoteRepositories ) |
271 | |
throws PluginVersionResolutionException, InvalidPluginException |
272 | |
{ |
273 | |
try |
274 | |
{ |
275 | 0 | Artifact artifact = artifactFactory.createProjectArtifact( plugin.getGroupId(), plugin.getArtifactId(), |
276 | |
plugin.getVersion() ); |
277 | 0 | MavenProject project = |
278 | |
mavenProjectBuilder.buildFromRepository( artifact, remoteRepositories, localRepository, false ); |
279 | |
|
280 | 0 | if ( ( project.getPrerequisites() != null ) && ( project.getPrerequisites().getMaven() != null ) ) |
281 | |
{ |
282 | 0 | DefaultArtifactVersion requiredVersion = |
283 | |
new DefaultArtifactVersion( project.getPrerequisites().getMaven() ); |
284 | 0 | if ( runtimeInformation.getApplicationVersion().compareTo( requiredVersion ) < 0 ) |
285 | |
{ |
286 | 0 | throw new PluginVersionResolutionException( plugin.getGroupId(), plugin.getArtifactId(), |
287 | |
"Plugin requires Maven version " + requiredVersion ); |
288 | |
} |
289 | |
} |
290 | |
} |
291 | 0 | catch ( ProjectBuildingException e ) |
292 | |
{ |
293 | 0 | throw new InvalidPluginException( |
294 | |
"Unable to build project for plugin '" + plugin.getKey() + "': " + e.getMessage(), e ); |
295 | 0 | } |
296 | 0 | } |
297 | |
|
298 | |
protected void addPlugin( Plugin plugin, |
299 | |
Artifact pluginArtifact, |
300 | |
MavenProject project, |
301 | |
ArtifactRepository localRepository ) |
302 | |
throws PluginManagerException, InvalidPluginException |
303 | |
{ |
304 | |
PlexusContainer child; |
305 | |
|
306 | |
try |
307 | |
{ |
308 | 0 | MavenPluginValidator validator = new MavenPluginValidator( pluginArtifact ); |
309 | |
|
310 | 0 | String key = PluginUtils.constructVersionedKey( plugin ).intern(); |
311 | 0 | child = container.createChildContainer( key, |
312 | |
Collections.singletonList( pluginArtifact.getFile() ), |
313 | |
Collections.EMPTY_MAP, |
314 | |
Arrays.asList( new ComponentDiscoveryListener[] { validator, pluginCollector } ) ); |
315 | |
|
316 | |
|
317 | |
|
318 | 0 | child.removeComponentDiscoveryListener( validator ); |
319 | 0 | child.removeComponentDiscoveryListener( pluginCollector ); |
320 | |
|
321 | 0 | if ( validator.hasErrors() ) |
322 | |
{ |
323 | 0 | String msg = "Plugin '" + key + "' has an invalid descriptor:"; |
324 | 0 | int count = 1; |
325 | 0 | for ( Iterator i = validator.getErrors().iterator(); i.hasNext(); ) |
326 | |
{ |
327 | 0 | msg += "\n" + count + ") " + i.next(); |
328 | 0 | count++; |
329 | |
} |
330 | 0 | throw new PluginManagerException( msg ); |
331 | |
} |
332 | |
|
333 | |
try |
334 | |
{ |
335 | 0 | child.getContainerRealm().importFrom( "plexus.core", "org.codehaus.plexus.util.xml.Xpp3Dom" ); |
336 | 0 | child.getContainerRealm().importFrom( "plexus.core", "org.codehaus.plexus.util.xml.pull.XmlPullParser" ); |
337 | 0 | child.getContainerRealm().importFrom( "plexus.core", "org.codehaus.plexus.util.xml.pull.XmlPullParserException" ); |
338 | 0 | child.getContainerRealm().importFrom( "plexus.core", "org.codehaus.plexus.util.xml.pull.XmlSerializer" ); |
339 | |
|
340 | |
|
341 | 0 | child.getContainerRealm().importFrom( "plexus.core", "/default-report.xml" ); |
342 | |
} |
343 | 0 | catch ( NoSuchRealmException e ) |
344 | |
{ |
345 | |
|
346 | 0 | } |
347 | |
} |
348 | 0 | catch ( PlexusContainerException e ) |
349 | |
{ |
350 | 0 | throw new PluginManagerException( |
351 | |
"Failed to create plugin container for plugin '" + plugin + "': " + e.getMessage(), e ); |
352 | 0 | } |
353 | |
|
354 | |
|
355 | |
|
356 | 0 | PluginDescriptor addedPlugin = pluginCollector.getPluginDescriptor( plugin ); |
357 | |
|
358 | 0 | if ( addedPlugin == null ) |
359 | |
{ |
360 | 0 | throw new IllegalStateException( "The plugin descriptor for the plugin " + plugin + " was not found." |
361 | |
+ " Please verify that the plugin JAR " + pluginArtifact.getFile() + " is intact." ); |
362 | |
} |
363 | |
|
364 | 0 | addedPlugin.setClassRealm( child.getContainerRealm() ); |
365 | |
|
366 | |
|
367 | |
|
368 | |
|
369 | 0 | addedPlugin.setArtifacts( Collections.singletonList( pluginArtifact ) ); |
370 | 0 | addedPlugin.setPluginArtifact( pluginArtifact ); |
371 | |
|
372 | |
try |
373 | |
{ |
374 | |
|
375 | |
|
376 | |
|
377 | 0 | Plugin projectPlugin = (Plugin) project.getBuild().getPluginsAsMap().get( plugin.getKey() ); |
378 | |
|
379 | 0 | if ( projectPlugin == null ) |
380 | |
{ |
381 | 0 | projectPlugin = plugin; |
382 | |
} |
383 | |
|
384 | 0 | Set artifacts = MavenMetadataSource.createArtifacts( artifactFactory, projectPlugin.getDependencies(), null, |
385 | |
null, project ); |
386 | |
|
387 | |
|
388 | |
|
389 | |
|
390 | 0 | addedPlugin.setIntroducedDependencyArtifacts( artifacts ); |
391 | |
} |
392 | 0 | catch ( InvalidDependencyVersionException e ) |
393 | |
{ |
394 | 0 | throw new InvalidPluginException( "Plugin '" + plugin + "' is invalid: " + e.getMessage(), e ); |
395 | 0 | } |
396 | 0 | } |
397 | |
|
398 | |
|
399 | |
|
400 | |
|
401 | |
|
402 | |
public void executeMojo( MavenProject project, |
403 | |
MojoExecution mojoExecution, |
404 | |
MavenSession session ) |
405 | |
throws ArtifactResolutionException, MojoExecutionException, MojoFailureException, ArtifactNotFoundException, |
406 | |
InvalidDependencyVersionException, PluginManagerException, PluginConfigurationException |
407 | |
{ |
408 | 0 | MojoDescriptor mojoDescriptor = mojoExecution.getMojoDescriptor(); |
409 | |
|
410 | |
|
411 | |
|
412 | 0 | if ( mojoDescriptor.isProjectRequired() && !session.isUsingPOMsFromFilesystem() ) |
413 | |
{ |
414 | 0 | throw new MojoExecutionException( "Cannot execute mojo: " + mojoDescriptor.getGoal() + |
415 | |
". It requires a project with an existing pom.xml, but the build is not using one." ); |
416 | |
} |
417 | |
|
418 | 0 | if ( mojoDescriptor.isOnlineRequired() && session.getSettings().isOffline() ) |
419 | |
{ |
420 | |
|
421 | 0 | throw new MojoExecutionException( "Mojo: " + mojoDescriptor.getGoal() + |
422 | |
" requires online mode for execution. Maven is currently offline." ); |
423 | |
} |
424 | |
|
425 | 0 | if ( mojoDescriptor.isDependencyResolutionRequired() != null ) |
426 | |
{ |
427 | |
Collection projects; |
428 | |
|
429 | 0 | if ( mojoDescriptor.isAggregator() ) |
430 | |
{ |
431 | 0 | projects = session.getSortedProjects(); |
432 | |
} |
433 | |
else |
434 | |
{ |
435 | 0 | projects = Collections.singleton( project ); |
436 | |
} |
437 | |
|
438 | 0 | for ( Iterator i = projects.iterator(); i.hasNext(); ) |
439 | |
{ |
440 | 0 | MavenProject p = (MavenProject) i.next(); |
441 | |
|
442 | 0 | resolveTransitiveDependencies( session, artifactResolver, |
443 | |
mojoDescriptor.isDependencyResolutionRequired(), artifactFactory, p, mojoDescriptor.isAggregator() ); |
444 | 0 | } |
445 | |
|
446 | 0 | downloadDependencies( project, session, artifactResolver ); |
447 | |
} |
448 | |
|
449 | 0 | String goalName = mojoDescriptor.getFullGoalName(); |
450 | |
|
451 | |
Mojo plugin; |
452 | |
|
453 | 0 | PluginDescriptor pluginDescriptor = mojoDescriptor.getPluginDescriptor(); |
454 | |
|
455 | 0 | String goalId = mojoDescriptor.getGoal(); |
456 | 0 | String groupId = pluginDescriptor.getGroupId(); |
457 | 0 | String artifactId = pluginDescriptor.getArtifactId(); |
458 | 0 | String executionId = mojoExecution.getExecutionId(); |
459 | |
|
460 | 0 | Xpp3Dom dom = project.getGoalConfiguration( groupId, artifactId, executionId, goalId ); |
461 | 0 | Xpp3Dom reportDom = project.getReportConfiguration( groupId, artifactId, executionId ); |
462 | 0 | dom = Xpp3Dom.mergeXpp3Dom( dom, reportDom ); |
463 | 0 | if ( mojoExecution.getConfiguration() != null ) |
464 | |
{ |
465 | 0 | dom = Xpp3Dom.mergeXpp3Dom( dom, mojoExecution.getConfiguration() ); |
466 | |
} |
467 | |
|
468 | 0 | plugin = getConfiguredMojo( session, dom, project, false, mojoExecution ); |
469 | |
|
470 | |
|
471 | 0 | String event = MavenEvents.MOJO_EXECUTION; |
472 | 0 | EventDispatcher dispatcher = session.getEventDispatcher(); |
473 | |
|
474 | 0 | String goalExecId = goalName; |
475 | |
|
476 | 0 | if ( mojoExecution.getExecutionId() != null ) |
477 | |
{ |
478 | 0 | goalExecId += " {execution: " + mojoExecution.getExecutionId() + "}"; |
479 | |
} |
480 | |
|
481 | 0 | dispatcher.dispatchStart( event, goalExecId ); |
482 | |
|
483 | 0 | ClassLoader oldClassLoader = Thread.currentThread().getContextClassLoader(); |
484 | |
|
485 | |
try |
486 | |
{ |
487 | 0 | Thread.currentThread().setContextClassLoader( |
488 | |
mojoDescriptor.getPluginDescriptor().getClassRealm().getClassLoader() ); |
489 | |
|
490 | 0 | plugin.execute(); |
491 | |
|
492 | 0 | dispatcher.dispatchEnd( event, goalExecId ); |
493 | |
} |
494 | 0 | catch ( MojoExecutionException e ) |
495 | |
{ |
496 | 0 | session.getEventDispatcher().dispatchError( event, goalExecId, e ); |
497 | |
|
498 | 0 | throw e; |
499 | |
} |
500 | 0 | catch ( MojoFailureException e ) |
501 | |
{ |
502 | 0 | session.getEventDispatcher().dispatchError( event, goalExecId, e ); |
503 | |
|
504 | 0 | throw e; |
505 | |
} |
506 | 0 | catch ( LinkageError e ) |
507 | |
{ |
508 | 0 | if ( getLogger().isFatalErrorEnabled() ) |
509 | |
{ |
510 | 0 | getLogger().fatalError( |
511 | |
plugin.getClass().getName() + "#execute() caused a linkage error (" |
512 | |
+ e.getClass().getName() + ") and may be out-of-date. Check the realms:" ); |
513 | |
|
514 | 0 | ClassRealm pluginRealm = mojoDescriptor.getPluginDescriptor().getClassRealm(); |
515 | 0 | StringBuffer sb = new StringBuffer(); |
516 | 0 | sb.append( "Plugin realm = " + pluginRealm.getId() ).append( '\n' ); |
517 | 0 | for ( int i = 0; i < pluginRealm.getConstituents().length; i++ ) |
518 | |
{ |
519 | 0 | sb.append( "urls[" + i + "] = " + pluginRealm.getConstituents()[i] ); |
520 | 0 | if ( i != ( pluginRealm.getConstituents().length - 1 ) ) |
521 | |
{ |
522 | 0 | sb.append( '\n' ); |
523 | |
} |
524 | |
} |
525 | 0 | getLogger().fatalError( sb.toString() ); |
526 | |
|
527 | 0 | ClassRealm containerRealm = container.getContainerRealm(); |
528 | 0 | sb = new StringBuffer(); |
529 | 0 | sb.append( "Container realm = " + containerRealm.getId() ).append( '\n' ); |
530 | 0 | for ( int i = 0; i < containerRealm.getConstituents().length; i++ ) |
531 | |
{ |
532 | 0 | sb.append( "urls[" + i + "] = " + containerRealm.getConstituents()[i] ); |
533 | 0 | if ( i != ( containerRealm.getConstituents().length - 1 ) ) |
534 | |
{ |
535 | 0 | sb.append( '\n' ); |
536 | |
} |
537 | |
} |
538 | 0 | getLogger().fatalError( sb.toString() ); |
539 | |
} |
540 | |
|
541 | 0 | session.getEventDispatcher().dispatchError( event, goalExecId, e ); |
542 | |
|
543 | 0 | throw e; |
544 | |
} |
545 | |
finally |
546 | |
{ |
547 | |
|
548 | 0 | Thread.currentThread().setContextClassLoader( oldClassLoader ); |
549 | |
|
550 | |
try |
551 | |
{ |
552 | 0 | PlexusContainer pluginContainer = getPluginContainer( mojoDescriptor.getPluginDescriptor() ); |
553 | |
|
554 | 0 | pluginContainer.release( plugin ); |
555 | |
} |
556 | 0 | catch ( ComponentLifecycleException e ) |
557 | |
{ |
558 | 0 | if ( getLogger().isErrorEnabled() ) |
559 | |
{ |
560 | 0 | getLogger().error( "Error releasing plugin - ignoring.", e ); |
561 | |
} |
562 | 0 | } |
563 | 0 | } |
564 | 0 | } |
565 | |
|
566 | |
|
567 | |
public MavenReport getReport( MavenProject project, |
568 | |
MojoExecution mojoExecution, |
569 | |
MavenSession session ) |
570 | |
throws ArtifactNotFoundException, PluginConfigurationException, PluginManagerException, |
571 | |
ArtifactResolutionException |
572 | |
{ |
573 | 0 | MojoDescriptor mojoDescriptor = mojoExecution.getMojoDescriptor(); |
574 | 0 | PluginDescriptor descriptor = mojoDescriptor.getPluginDescriptor(); |
575 | |
|
576 | 0 | Xpp3Dom dom = project.getReportConfiguration( descriptor.getGroupId(), descriptor.getArtifactId(), |
577 | |
mojoExecution.getExecutionId() ); |
578 | 0 | if ( mojoExecution.getConfiguration() != null ) |
579 | |
{ |
580 | 0 | dom = Xpp3Dom.mergeXpp3Dom( dom, mojoExecution.getConfiguration() ); |
581 | |
} |
582 | |
|
583 | 0 | MavenReport report = (MavenReport) getConfiguredMojo( session, dom, project, true, mojoExecution ); |
584 | |
|
585 | 0 | return report; |
586 | |
} |
587 | |
|
588 | |
public PluginDescriptor verifyReportPlugin( ReportPlugin reportPlugin, |
589 | |
MavenProject project, |
590 | |
MavenSession session ) |
591 | |
throws PluginVersionResolutionException, ArtifactResolutionException, ArtifactNotFoundException, |
592 | |
InvalidVersionSpecificationException, InvalidPluginException, PluginManagerException, PluginNotFoundException, |
593 | |
PluginVersionNotFoundException |
594 | |
{ |
595 | 0 | String version = reportPlugin.getVersion(); |
596 | |
|
597 | 0 | if ( version == null ) |
598 | |
{ |
599 | 0 | version = pluginVersionManager.resolveReportPluginVersion( reportPlugin.getGroupId(), |
600 | |
reportPlugin.getArtifactId(), project, |
601 | |
session.getSettings(), |
602 | |
session.getLocalRepository() ); |
603 | 0 | reportPlugin.setVersion( version ); |
604 | |
} |
605 | |
|
606 | 0 | Plugin forLookup = new Plugin(); |
607 | |
|
608 | 0 | forLookup.setGroupId( reportPlugin.getGroupId() ); |
609 | 0 | forLookup.setArtifactId( reportPlugin.getArtifactId() ); |
610 | 0 | forLookup.setVersion( version ); |
611 | |
|
612 | 0 | return verifyVersionedPlugin( forLookup, project, session.getLocalRepository() ); |
613 | |
} |
614 | |
|
615 | |
private PlexusContainer getPluginContainer( PluginDescriptor pluginDescriptor ) |
616 | |
throws PluginManagerException |
617 | |
{ |
618 | 0 | String pluginKey = PluginUtils.constructVersionedKey( pluginDescriptor ); |
619 | |
|
620 | 0 | PlexusContainer pluginContainer = container.getChildContainer( pluginKey ); |
621 | |
|
622 | 0 | if ( pluginContainer == null ) |
623 | |
{ |
624 | 0 | throw new PluginManagerException( "Cannot find Plexus container for plugin: " + pluginKey ); |
625 | |
} |
626 | |
|
627 | 0 | return pluginContainer; |
628 | |
} |
629 | |
|
630 | |
private Mojo getConfiguredMojo( MavenSession session, |
631 | |
Xpp3Dom dom, |
632 | |
MavenProject project, |
633 | |
boolean report, |
634 | |
MojoExecution mojoExecution ) |
635 | |
throws PluginConfigurationException, ArtifactNotFoundException, PluginManagerException, |
636 | |
ArtifactResolutionException |
637 | |
{ |
638 | 0 | MojoDescriptor mojoDescriptor = mojoExecution.getMojoDescriptor(); |
639 | |
|
640 | 0 | PluginDescriptor pluginDescriptor = mojoDescriptor.getPluginDescriptor(); |
641 | |
|
642 | 0 | PlexusContainer pluginContainer = getPluginContainer( pluginDescriptor ); |
643 | |
|
644 | |
|
645 | |
|
646 | |
|
647 | 0 | ensurePluginContainerIsComplete( pluginDescriptor, pluginContainer, project, session ); |
648 | |
|
649 | |
Mojo plugin; |
650 | |
try |
651 | |
{ |
652 | 0 | plugin = (Mojo) pluginContainer.lookup( Mojo.ROLE, mojoDescriptor.getRoleHint() ); |
653 | 0 | if ( report && !( plugin instanceof MavenReport ) ) |
654 | |
{ |
655 | |
|
656 | 0 | return null; |
657 | |
} |
658 | |
} |
659 | 0 | catch ( ComponentLookupException e ) |
660 | |
{ |
661 | 0 | Throwable cause = e.getCause(); |
662 | 0 | while( cause != null && !(cause instanceof NoClassDefFoundError ) ) |
663 | |
{ |
664 | 0 | cause = cause.getCause(); |
665 | |
} |
666 | |
|
667 | 0 | if ( cause != null && ( cause instanceof NoClassDefFoundError ) ) |
668 | |
{ |
669 | 0 | throw new PluginManagerException( "Unable to load the mojo '" + mojoDescriptor.getRoleHint() |
670 | |
+ "' in the plugin '" + pluginDescriptor.getPluginLookupKey() + "'. A required class is missing: " |
671 | |
+ cause.getMessage(), e ); |
672 | |
} |
673 | |
|
674 | 0 | throw new PluginManagerException( "Unable to find the mojo '" + mojoDescriptor.getGoal() + |
675 | |
"' (or one of its required components) in the plugin '" + pluginDescriptor.getPluginLookupKey() + "'", e ); |
676 | |
} |
677 | 0 | catch ( NoClassDefFoundError e ) |
678 | |
{ |
679 | 0 | throw new PluginManagerException( "Unable to load the mojo '" + mojoDescriptor.getRoleHint() |
680 | |
+ "' in the plugin '" + pluginDescriptor.getPluginLookupKey() + "'. A required class is missing: " |
681 | |
+ e.getMessage(), e ); |
682 | 0 | } |
683 | |
|
684 | 0 | if ( plugin instanceof ContextEnabled ) |
685 | |
{ |
686 | 0 | Map pluginContext = session.getPluginContext( pluginDescriptor, project ); |
687 | |
|
688 | 0 | ( (ContextEnabled) plugin ).setPluginContext( pluginContext ); |
689 | |
} |
690 | |
|
691 | 0 | plugin.setLog( mojoLogger ); |
692 | |
|
693 | |
XmlPlexusConfiguration pomConfiguration; |
694 | 0 | if ( dom == null ) |
695 | |
{ |
696 | 0 | pomConfiguration = new XmlPlexusConfiguration( "configuration" ); |
697 | |
} |
698 | |
else |
699 | |
{ |
700 | 0 | pomConfiguration = new XmlPlexusConfiguration( dom ); |
701 | |
} |
702 | |
|
703 | |
|
704 | |
|
705 | 0 | validatePomConfiguration( mojoDescriptor, pomConfiguration ); |
706 | |
|
707 | 0 | PlexusConfiguration mergedConfiguration = mergeMojoConfiguration( pomConfiguration, mojoDescriptor ); |
708 | |
|
709 | |
|
710 | |
|
711 | |
|
712 | |
|
713 | 0 | ExpressionEvaluator expressionEvaluator = new PluginParameterExpressionEvaluator( session, mojoExecution, |
714 | |
pathTranslator, |
715 | |
getLogger(), |
716 | |
project, |
717 | |
session.getExecutionProperties() ); |
718 | |
|
719 | 0 | PlexusConfiguration extractedMojoConfiguration = |
720 | |
extractMojoConfiguration( mergedConfiguration, mojoDescriptor ); |
721 | |
|
722 | 0 | checkRequiredParameters( mojoDescriptor, extractedMojoConfiguration, expressionEvaluator ); |
723 | |
|
724 | 0 | populatePluginFields( plugin, mojoDescriptor, extractedMojoConfiguration, pluginContainer, |
725 | |
expressionEvaluator ); |
726 | 0 | return plugin; |
727 | |
} |
728 | |
|
729 | |
private void ensurePluginContainerIsComplete( PluginDescriptor pluginDescriptor, |
730 | |
PlexusContainer pluginContainer, |
731 | |
MavenProject project, |
732 | |
MavenSession session ) |
733 | |
throws ArtifactNotFoundException, PluginManagerException, ArtifactResolutionException |
734 | |
{ |
735 | |
|
736 | |
|
737 | 0 | if ( ( pluginDescriptor.getArtifacts() != null ) && ( pluginDescriptor.getArtifacts().size() == 1 ) ) |
738 | |
{ |
739 | 0 | Artifact pluginArtifact = (Artifact) pluginDescriptor.getArtifacts().get( 0 ); |
740 | |
|
741 | 0 | ArtifactRepository localRepository = session.getLocalRepository(); |
742 | |
|
743 | |
ResolutionGroup resolutionGroup; |
744 | |
try |
745 | |
{ |
746 | 0 | resolutionGroup = artifactMetadataSource.retrieve( pluginArtifact, localRepository, |
747 | |
project.getPluginArtifactRepositories() ); |
748 | |
} |
749 | 0 | catch ( ArtifactMetadataRetrievalException e ) |
750 | |
{ |
751 | 0 | throw new ArtifactResolutionException( "Unable to download metadata from repository for plugin '" + |
752 | |
pluginArtifact.getId() + "': " + e.getMessage(), pluginArtifact, e ); |
753 | 0 | } |
754 | |
|
755 | 0 | Set rgArtifacts = resolutionGroup.getArtifacts(); |
756 | |
|
757 | 0 | rgArtifacts = checkPlexusUtils( rgArtifacts, artifactFactory ); |
758 | |
|
759 | |
|
760 | |
|
761 | |
|
762 | |
|
763 | |
|
764 | |
|
765 | |
|
766 | |
|
767 | |
|
768 | |
|
769 | |
|
770 | |
|
771 | |
|
772 | |
|
773 | |
|
774 | |
|
775 | |
|
776 | 0 | Map dependencyMap = new LinkedHashMap(); |
777 | |
|
778 | |
|
779 | |
|
780 | 0 | List all = new ArrayList(); |
781 | |
|
782 | |
|
783 | |
|
784 | 0 | all.addAll( pluginDescriptor.getIntroducedDependencyArtifacts() ); |
785 | |
|
786 | |
|
787 | 0 | all.addAll( rgArtifacts ); |
788 | |
|
789 | 0 | for ( Iterator it = all.iterator(); it.hasNext(); ) |
790 | |
{ |
791 | 0 | Artifact artifact = (Artifact) it.next(); |
792 | 0 | String conflictId = artifact.getDependencyConflictId(); |
793 | |
|
794 | |
|
795 | |
|
796 | |
|
797 | 0 | if ( !dependencyMap.containsKey( conflictId ) ) |
798 | |
{ |
799 | 0 | dependencyMap.put( conflictId, artifact ); |
800 | |
} |
801 | 0 | } |
802 | |
|
803 | |
|
804 | 0 | Set dependencies = new LinkedHashSet( dependencyMap.values() ); |
805 | |
|
806 | 0 | if ( getLogger().isDebugEnabled() ) |
807 | |
{ |
808 | |
|
809 | 0 | getLogger().debug( "Plugin dependencies for:\n\n" + pluginDescriptor.getId() |
810 | |
+ "\n\nare:\n\n" |
811 | |
+ StringUtils.join( dependencies.iterator(), "\n" ) + "\n\n" ); |
812 | |
} |
813 | |
|
814 | 0 | List repositories = new ArrayList(); |
815 | 0 | repositories.addAll( resolutionGroup.getResolutionRepositories() ); |
816 | 0 | repositories.addAll( project.getRemoteArtifactRepositories() ); |
817 | |
|
818 | |
|
819 | 0 | Map pluginManagedDependencies = new HashMap(); |
820 | |
try |
821 | |
{ |
822 | 0 | MavenProject pluginProject = |
823 | |
mavenProjectBuilder.buildFromRepository( pluginArtifact, project.getRemoteArtifactRepositories(), |
824 | |
localRepository ); |
825 | 0 | if ( pluginProject != null ) |
826 | |
{ |
827 | 0 | pluginManagedDependencies = pluginProject.getManagedVersionMap(); |
828 | |
} |
829 | |
} |
830 | 0 | catch ( ProjectBuildingException e ) |
831 | |
{ |
832 | |
|
833 | 0 | } |
834 | |
|
835 | 0 | ArtifactResolutionResult result = artifactResolver.resolveTransitively( dependencies, pluginArtifact, |
836 | |
pluginManagedDependencies, |
837 | |
localRepository, repositories, |
838 | |
artifactMetadataSource, |
839 | |
artifactFilter ); |
840 | |
|
841 | 0 | Set resolved = result.getArtifacts(); |
842 | |
|
843 | 0 | for ( Iterator it = resolved.iterator(); it.hasNext(); ) |
844 | |
{ |
845 | 0 | Artifact artifact = (Artifact) it.next(); |
846 | |
|
847 | 0 | if ( !artifact.equals( pluginArtifact ) ) |
848 | |
{ |
849 | 0 | artifact = project.replaceWithActiveArtifact( artifact ); |
850 | |
|
851 | |
try |
852 | |
{ |
853 | 0 | pluginContainer.addJarResource( artifact.getFile() ); |
854 | |
} |
855 | 0 | catch ( PlexusContainerException e ) |
856 | |
{ |
857 | 0 | throw new PluginManagerException( "Error adding plugin dependency '" + |
858 | |
artifact.getDependencyConflictId() + "' into plugin manager: " + e.getMessage(), e ); |
859 | 0 | } |
860 | |
} |
861 | 0 | } |
862 | |
|
863 | 0 | pluginDescriptor.setClassRealm( pluginContainer.getContainerRealm() ); |
864 | |
|
865 | 0 | List unresolved = new ArrayList( dependencies ); |
866 | |
|
867 | 0 | unresolved.removeAll( resolved ); |
868 | |
|
869 | 0 | if ( getLogger().isDebugEnabled() ) |
870 | |
{ |
871 | |
|
872 | |
|
873 | 0 | getLogger().debug( " The following artifacts were filtered out for plugin: " |
874 | |
+ pluginDescriptor.getId() |
875 | |
+ " because they're already in the core of Maven:\n\n" |
876 | |
+ StringUtils.join( unresolved.iterator(), "\n" ) |
877 | |
+ "\n\nThese will use the artifact files already in the core ClassRealm instead, to allow them to be included in PluginDescriptor.getArtifacts().\n\n" ); |
878 | |
} |
879 | |
|
880 | |
|
881 | |
|
882 | |
|
883 | 0 | resolveCoreArtifacts( unresolved, localRepository, resolutionGroup.getResolutionRepositories() ); |
884 | |
|
885 | |
|
886 | |
|
887 | |
|
888 | |
|
889 | |
|
890 | 0 | List allResolved = new ArrayList( resolved.size() + unresolved.size() ); |
891 | |
|
892 | 0 | allResolved.addAll( resolved ); |
893 | 0 | allResolved.addAll( unresolved ); |
894 | |
|
895 | 0 | pluginDescriptor.setArtifacts( allResolved ); |
896 | |
} |
897 | 0 | } |
898 | |
|
899 | |
public static Set checkPlexusUtils( Set dependencyArtifacts, ArtifactFactory artifactFactory ) |
900 | |
{ |
901 | |
|
902 | |
|
903 | |
|
904 | |
|
905 | |
|
906 | |
|
907 | |
|
908 | |
|
909 | |
|
910 | |
|
911 | 0 | VersionRange vr = null; |
912 | |
|
913 | |
try |
914 | |
{ |
915 | 0 | vr = VersionRange.createFromVersionSpec( "[1.1,)" ); |
916 | |
} |
917 | 0 | catch ( InvalidVersionSpecificationException e ) |
918 | |
{ |
919 | |
|
920 | 0 | } |
921 | |
|
922 | 0 | boolean plexusUtilsPresent = false; |
923 | |
|
924 | 0 | for ( Iterator i = dependencyArtifacts.iterator(); i.hasNext(); ) |
925 | |
{ |
926 | 0 | Artifact a = (Artifact) i.next(); |
927 | |
|
928 | 0 | if ( a.getArtifactId().equals( "plexus-utils" ) && |
929 | |
vr.containsVersion( new DefaultArtifactVersion( a.getVersion() ) ) ) |
930 | |
{ |
931 | 0 | plexusUtilsPresent = true; |
932 | |
|
933 | 0 | break; |
934 | |
} |
935 | 0 | } |
936 | |
|
937 | 0 | if ( !plexusUtilsPresent ) |
938 | |
{ |
939 | |
|
940 | |
|
941 | |
|
942 | |
|
943 | 0 | Set result = new LinkedHashSet(); |
944 | 0 | if ( !dependencyArtifacts.isEmpty() ) |
945 | |
{ |
946 | 0 | result.addAll( dependencyArtifacts ); |
947 | |
} |
948 | |
|
949 | 0 | result.add( artifactFactory.createArtifact( "org.codehaus.plexus", "plexus-utils", "1.1", Artifact.SCOPE_RUNTIME, "jar" ) ); |
950 | |
|
951 | 0 | return result; |
952 | |
} |
953 | |
else |
954 | |
{ |
955 | 0 | return dependencyArtifacts; |
956 | |
} |
957 | |
} |
958 | |
|
959 | |
private void resolveCoreArtifacts( List unresolved, |
960 | |
ArtifactRepository localRepository, |
961 | |
List resolutionRepositories ) |
962 | |
throws ArtifactResolutionException, ArtifactNotFoundException |
963 | |
{ |
964 | 0 | for ( Iterator it = unresolved.iterator(); it.hasNext(); ) |
965 | |
{ |
966 | 0 | Artifact artifact = (Artifact) it.next(); |
967 | |
|
968 | 0 | File artifactFile = (File) resolvedCoreArtifactFiles.get( artifact.getId() ); |
969 | |
|
970 | 0 | if ( artifactFile == null ) |
971 | |
{ |
972 | 0 | String resource = |
973 | |
"/META-INF/maven/" + artifact.getGroupId() + "/" + artifact.getArtifactId() + "/pom.xml"; |
974 | |
|
975 | 0 | URL resourceUrl = container.getContainerRealm().getResource( resource ); |
976 | |
|
977 | 0 | if ( resourceUrl == null ) |
978 | |
{ |
979 | 0 | artifactResolver.resolve( artifact, resolutionRepositories, localRepository ); |
980 | |
|
981 | 0 | artifactFile = artifact.getFile(); |
982 | |
} |
983 | |
else |
984 | |
{ |
985 | 0 | String artifactPath = resourceUrl.getPath(); |
986 | |
|
987 | 0 | if ( artifactPath.startsWith( "file:" ) ) |
988 | |
{ |
989 | 0 | artifactPath = artifactPath.substring( "file:".length() ); |
990 | |
} |
991 | |
|
992 | 0 | artifactPath = artifactPath.substring( 0, artifactPath.length() - resource.length() ); |
993 | |
|
994 | 0 | if ( artifactPath.endsWith( "/" ) ) |
995 | |
{ |
996 | 0 | artifactPath = artifactPath.substring( 0, artifactPath.length() - 1 ); |
997 | |
} |
998 | |
|
999 | 0 | if ( artifactPath.endsWith( "!" ) ) |
1000 | |
{ |
1001 | 0 | artifactPath = artifactPath.substring( 0, artifactPath.length() - 1 ); |
1002 | |
} |
1003 | |
|
1004 | 0 | artifactFile = new File( artifactPath ).getAbsoluteFile(); |
1005 | |
} |
1006 | |
|
1007 | 0 | resolvedCoreArtifactFiles.put( artifact.getId(), artifactFile ); |
1008 | |
} |
1009 | |
|
1010 | 0 | artifact.setFile( artifactFile ); |
1011 | 0 | } |
1012 | 0 | } |
1013 | |
|
1014 | |
private PlexusConfiguration extractMojoConfiguration( PlexusConfiguration mergedConfiguration, |
1015 | |
MojoDescriptor mojoDescriptor ) |
1016 | |
{ |
1017 | 0 | Map parameterMap = mojoDescriptor.getParameterMap(); |
1018 | |
|
1019 | 0 | PlexusConfiguration[] mergedChildren = mergedConfiguration.getChildren(); |
1020 | |
|
1021 | 0 | XmlPlexusConfiguration extractedConfiguration = new XmlPlexusConfiguration( "configuration" ); |
1022 | |
|
1023 | 0 | for ( int i = 0; i < mergedChildren.length; i++ ) |
1024 | |
{ |
1025 | 0 | PlexusConfiguration child = mergedChildren[i]; |
1026 | |
|
1027 | 0 | if ( parameterMap.containsKey( child.getName() ) ) |
1028 | |
{ |
1029 | 0 | extractedConfiguration.addChild( copyConfiguration( child ) ); |
1030 | |
} |
1031 | |
else |
1032 | |
{ |
1033 | |
|
1034 | |
|
1035 | |
|
1036 | |
|
1037 | 0 | getLogger().debug( "*** WARNING: Configuration \'" + child.getName() + "\' is not used in goal \'" + |
1038 | |
mojoDescriptor.getFullGoalName() + "; this may indicate a typo... ***" ); |
1039 | |
} |
1040 | |
} |
1041 | |
|
1042 | 0 | return extractedConfiguration; |
1043 | |
} |
1044 | |
|
1045 | |
private void checkRequiredParameters( MojoDescriptor goal, |
1046 | |
PlexusConfiguration configuration, |
1047 | |
ExpressionEvaluator expressionEvaluator ) |
1048 | |
throws PluginConfigurationException |
1049 | |
{ |
1050 | |
|
1051 | |
|
1052 | 0 | List parameters = goal.getParameters(); |
1053 | |
|
1054 | 0 | if ( parameters == null ) |
1055 | |
{ |
1056 | 0 | return; |
1057 | |
} |
1058 | |
|
1059 | 0 | List invalidParameters = new ArrayList(); |
1060 | |
|
1061 | 0 | for ( int i = 0; i < parameters.size(); i++ ) |
1062 | |
{ |
1063 | 0 | Parameter parameter = (Parameter) parameters.get( i ); |
1064 | |
|
1065 | 0 | if ( parameter.isRequired() ) |
1066 | |
{ |
1067 | |
|
1068 | 0 | String key = parameter.getName(); |
1069 | |
|
1070 | 0 | Object fieldValue = null; |
1071 | 0 | String expression = null; |
1072 | 0 | PlexusConfiguration value = configuration.getChild( key, false ); |
1073 | |
try |
1074 | |
{ |
1075 | 0 | if ( value != null ) |
1076 | |
{ |
1077 | 0 | expression = value.getValue( null ); |
1078 | |
|
1079 | 0 | fieldValue = expressionEvaluator.evaluate( expression ); |
1080 | |
|
1081 | 0 | if ( fieldValue == null ) |
1082 | |
{ |
1083 | 0 | fieldValue = value.getAttribute( "default-value", null ); |
1084 | |
} |
1085 | |
} |
1086 | |
|
1087 | 0 | if ( ( fieldValue == null ) && StringUtils.isNotEmpty( parameter.getAlias() ) ) |
1088 | |
{ |
1089 | 0 | value = configuration.getChild( parameter.getAlias(), false ); |
1090 | 0 | if ( value != null ) |
1091 | |
{ |
1092 | 0 | expression = value.getValue( null ); |
1093 | 0 | fieldValue = expressionEvaluator.evaluate( expression ); |
1094 | 0 | if ( fieldValue == null ) |
1095 | |
{ |
1096 | 0 | fieldValue = value.getAttribute( "default-value", null ); |
1097 | |
} |
1098 | |
} |
1099 | |
} |
1100 | |
} |
1101 | 0 | catch ( ExpressionEvaluationException e ) |
1102 | |
{ |
1103 | 0 | throw new PluginConfigurationException( goal.getPluginDescriptor(), e.getMessage(), e ); |
1104 | 0 | } |
1105 | |
|
1106 | |
|
1107 | 0 | if ( ( fieldValue == null ) && ( ( value == null ) || ( value.getChildCount() == 0 ) ) ) |
1108 | |
{ |
1109 | 0 | parameter.setExpression( expression ); |
1110 | 0 | invalidParameters.add( parameter ); |
1111 | |
} |
1112 | |
} |
1113 | |
} |
1114 | |
|
1115 | 0 | if ( !invalidParameters.isEmpty() ) |
1116 | |
{ |
1117 | 0 | throw new PluginParameterException( goal, invalidParameters ); |
1118 | |
} |
1119 | 0 | } |
1120 | |
|
1121 | |
private void validatePomConfiguration( MojoDescriptor goal, |
1122 | |
PlexusConfiguration pomConfiguration ) |
1123 | |
throws PluginConfigurationException |
1124 | |
{ |
1125 | 0 | List parameters = goal.getParameters(); |
1126 | |
|
1127 | 0 | if ( parameters == null ) |
1128 | |
{ |
1129 | 0 | return; |
1130 | |
} |
1131 | |
|
1132 | 0 | for ( int i = 0; i < parameters.size(); i++ ) |
1133 | |
{ |
1134 | 0 | Parameter parameter = (Parameter) parameters.get( i ); |
1135 | |
|
1136 | |
|
1137 | 0 | String key = parameter.getName(); |
1138 | |
|
1139 | 0 | PlexusConfiguration value = pomConfiguration.getChild( key, false ); |
1140 | |
|
1141 | 0 | if ( ( value == null ) && StringUtils.isNotEmpty( parameter.getAlias() ) ) |
1142 | |
{ |
1143 | 0 | key = parameter.getAlias(); |
1144 | 0 | value = pomConfiguration.getChild( key, false ); |
1145 | |
} |
1146 | |
|
1147 | 0 | if ( value != null ) |
1148 | |
{ |
1149 | |
|
1150 | 0 | if ( !parameter.isEditable() ) |
1151 | |
{ |
1152 | 0 | StringBuffer errorMessage = new StringBuffer() |
1153 | |
.append( "ERROR: Cannot override read-only parameter: " ); |
1154 | 0 | errorMessage.append( key ); |
1155 | 0 | errorMessage.append( " in goal: " ).append( goal.getFullGoalName() ); |
1156 | |
|
1157 | 0 | throw new PluginConfigurationException( goal.getPluginDescriptor(), errorMessage.toString() ); |
1158 | |
} |
1159 | |
|
1160 | 0 | String deprecated = parameter.getDeprecated(); |
1161 | 0 | if ( StringUtils.isNotEmpty( deprecated ) ) |
1162 | |
{ |
1163 | 0 | getLogger().warn( "DEPRECATED [" + parameter.getName() + "]: " + deprecated ); |
1164 | |
} |
1165 | |
} |
1166 | |
} |
1167 | 0 | } |
1168 | |
|
1169 | |
private PlexusConfiguration mergeMojoConfiguration( XmlPlexusConfiguration fromPom, |
1170 | |
MojoDescriptor mojoDescriptor ) |
1171 | |
{ |
1172 | 0 | XmlPlexusConfiguration result = new XmlPlexusConfiguration( fromPom.getName() ); |
1173 | 0 | result.setValue( fromPom.getValue( null ) ); |
1174 | |
|
1175 | 0 | if ( mojoDescriptor.getParameters() != null ) |
1176 | |
{ |
1177 | 0 | PlexusConfiguration fromMojo = mojoDescriptor.getMojoConfiguration(); |
1178 | |
|
1179 | 0 | for ( Iterator it = mojoDescriptor.getParameters().iterator(); it.hasNext(); ) |
1180 | |
{ |
1181 | 0 | Parameter parameter = (Parameter) it.next(); |
1182 | |
|
1183 | 0 | String paramName = parameter.getName(); |
1184 | 0 | String alias = parameter.getAlias(); |
1185 | 0 | String implementation = parameter.getImplementation(); |
1186 | |
|
1187 | 0 | PlexusConfiguration pomConfig = fromPom.getChild( paramName ); |
1188 | 0 | PlexusConfiguration aliased = null; |
1189 | |
|
1190 | 0 | if ( alias != null ) |
1191 | |
{ |
1192 | 0 | aliased = fromPom.getChild( alias ); |
1193 | |
} |
1194 | |
|
1195 | 0 | PlexusConfiguration mojoConfig = fromMojo.getChild( paramName, false ); |
1196 | |
|
1197 | |
|
1198 | |
|
1199 | 0 | if ( aliased != null ) |
1200 | |
{ |
1201 | 0 | if ( pomConfig == null ) |
1202 | |
{ |
1203 | 0 | pomConfig = new XmlPlexusConfiguration( paramName ); |
1204 | |
} |
1205 | |
|
1206 | 0 | pomConfig = buildTopDownMergedConfiguration( pomConfig, aliased ); |
1207 | |
} |
1208 | |
|
1209 | 0 | PlexusConfiguration toAdd = null; |
1210 | |
|
1211 | 0 | if ( pomConfig != null ) |
1212 | |
{ |
1213 | 0 | pomConfig = buildTopDownMergedConfiguration( pomConfig, mojoConfig ); |
1214 | |
|
1215 | 0 | if ( StringUtils.isNotEmpty( pomConfig.getValue( null ) ) || ( pomConfig.getChildCount() > 0 ) ) |
1216 | |
{ |
1217 | 0 | toAdd = pomConfig; |
1218 | |
} |
1219 | |
} |
1220 | |
|
1221 | 0 | if ( ( toAdd == null ) && ( mojoConfig != null ) ) |
1222 | |
{ |
1223 | 0 | toAdd = copyConfiguration( mojoConfig ); |
1224 | |
} |
1225 | |
|
1226 | 0 | if ( toAdd != null ) |
1227 | |
{ |
1228 | 0 | if ( ( implementation != null ) && ( toAdd.getAttribute( "implementation", null ) == null ) ) |
1229 | |
{ |
1230 | |
|
1231 | 0 | XmlPlexusConfiguration implementationConf = new XmlPlexusConfiguration( paramName ); |
1232 | |
|
1233 | 0 | implementationConf.setAttribute( "implementation", parameter.getImplementation() ); |
1234 | |
|
1235 | 0 | toAdd = buildTopDownMergedConfiguration( toAdd, implementationConf ); |
1236 | |
} |
1237 | |
|
1238 | 0 | result.addChild( toAdd ); |
1239 | |
} |
1240 | 0 | } |
1241 | |
} |
1242 | 0 | return result; |
1243 | |
} |
1244 | |
|
1245 | |
private XmlPlexusConfiguration buildTopDownMergedConfiguration( PlexusConfiguration dominant, |
1246 | |
PlexusConfiguration recessive ) |
1247 | |
{ |
1248 | 0 | XmlPlexusConfiguration result = new XmlPlexusConfiguration( dominant.getName() ); |
1249 | |
|
1250 | 0 | String value = dominant.getValue( null ); |
1251 | |
|
1252 | 0 | if ( StringUtils.isEmpty( value ) && ( recessive != null ) ) |
1253 | |
{ |
1254 | 0 | value = recessive.getValue( null ); |
1255 | |
} |
1256 | |
|
1257 | 0 | if ( StringUtils.isNotEmpty( value ) ) |
1258 | |
{ |
1259 | 0 | result.setValue( value ); |
1260 | |
} |
1261 | |
|
1262 | 0 | String[] attributeNames = dominant.getAttributeNames(); |
1263 | |
|
1264 | 0 | for ( int i = 0; i < attributeNames.length; i++ ) |
1265 | |
{ |
1266 | 0 | String attributeValue = dominant.getAttribute( attributeNames[i], null ); |
1267 | |
|
1268 | 0 | result.setAttribute( attributeNames[i], attributeValue ); |
1269 | |
} |
1270 | |
|
1271 | 0 | if ( recessive != null ) |
1272 | |
{ |
1273 | 0 | attributeNames = recessive.getAttributeNames(); |
1274 | |
|
1275 | 0 | for ( int i = 0; i < attributeNames.length; i++ ) |
1276 | |
{ |
1277 | 0 | String attributeValue = recessive.getAttribute( attributeNames[i], null ); |
1278 | |
|
1279 | 0 | result.setAttribute( attributeNames[i], attributeValue ); |
1280 | |
} |
1281 | |
} |
1282 | |
|
1283 | 0 | PlexusConfiguration[] children = dominant.getChildren(); |
1284 | |
|
1285 | 0 | for ( int i = 0; i < children.length; i++ ) |
1286 | |
{ |
1287 | 0 | PlexusConfiguration childDom = children[i]; |
1288 | 0 | PlexusConfiguration childRec = recessive == null ? null : recessive.getChild( childDom.getName(), false ); |
1289 | |
|
1290 | 0 | if ( childRec != null ) |
1291 | |
{ |
1292 | 0 | result.addChild( buildTopDownMergedConfiguration( childDom, childRec ) ); |
1293 | |
} |
1294 | |
else |
1295 | |
{ |
1296 | 0 | result.addChild( copyConfiguration( childDom ) ); |
1297 | |
} |
1298 | |
} |
1299 | |
|
1300 | 0 | return result; |
1301 | |
} |
1302 | |
|
1303 | |
public static PlexusConfiguration copyConfiguration( PlexusConfiguration src ) |
1304 | |
{ |
1305 | |
|
1306 | 0 | XmlPlexusConfiguration dom = new XmlPlexusConfiguration( src.getName() ); |
1307 | 0 | dom.setValue( src.getValue( null ) ); |
1308 | |
|
1309 | 0 | String[] attributeNames = src.getAttributeNames(); |
1310 | 0 | for ( int i = 0; i < attributeNames.length; i++ ) |
1311 | |
{ |
1312 | 0 | String attributeName = attributeNames[i]; |
1313 | 0 | dom.setAttribute( attributeName, src.getAttribute( attributeName, null ) ); |
1314 | |
} |
1315 | |
|
1316 | 0 | PlexusConfiguration[] children = src.getChildren(); |
1317 | 0 | for ( int i = 0; i < children.length; i++ ) |
1318 | |
{ |
1319 | 0 | dom.addChild( copyConfiguration( children[i] ) ); |
1320 | |
} |
1321 | |
|
1322 | 0 | return dom; |
1323 | |
} |
1324 | |
|
1325 | |
|
1326 | |
|
1327 | |
|
1328 | |
|
1329 | |
private void populatePluginFields( Mojo plugin, |
1330 | |
MojoDescriptor mojoDescriptor, |
1331 | |
PlexusConfiguration configuration, |
1332 | |
PlexusContainer pluginContainer, |
1333 | |
ExpressionEvaluator expressionEvaluator ) |
1334 | |
throws PluginConfigurationException |
1335 | |
{ |
1336 | 0 | ComponentConfigurator configurator = null; |
1337 | |
|
1338 | |
try |
1339 | |
{ |
1340 | 0 | String configuratorId = mojoDescriptor.getComponentConfigurator(); |
1341 | |
|
1342 | |
|
1343 | |
|
1344 | 0 | if ( StringUtils.isNotEmpty( configuratorId ) ) |
1345 | |
{ |
1346 | 0 | configurator = |
1347 | |
(ComponentConfigurator) pluginContainer.lookup( ComponentConfigurator.ROLE, configuratorId ); |
1348 | |
} |
1349 | |
else |
1350 | |
{ |
1351 | 0 | configurator = (ComponentConfigurator) pluginContainer.lookup( ComponentConfigurator.ROLE ); |
1352 | |
} |
1353 | |
|
1354 | 0 | ConfigurationListener listener = new DebugConfigurationListener( getLogger() ); |
1355 | |
|
1356 | 0 | getLogger().debug( "Configuring mojo '" + mojoDescriptor.getId() + "' -->" ); |
1357 | 0 | configurator.configureComponent( plugin, configuration, expressionEvaluator, |
1358 | |
pluginContainer.getContainerRealm(), listener ); |
1359 | 0 | getLogger().debug( "-- end configuration --" ); |
1360 | |
} |
1361 | 0 | catch ( ComponentConfigurationException e ) |
1362 | |
{ |
1363 | 0 | throw new PluginConfigurationException( mojoDescriptor.getPluginDescriptor(), |
1364 | |
"Unable to parse the created DOM for plugin configuration", e ); |
1365 | |
} |
1366 | 0 | catch ( ComponentLookupException e ) |
1367 | |
{ |
1368 | 0 | throw new PluginConfigurationException( mojoDescriptor.getPluginDescriptor(), |
1369 | |
"Unable to retrieve component configurator for plugin configuration", |
1370 | |
e ); |
1371 | |
} |
1372 | 0 | catch ( NoClassDefFoundError e ) |
1373 | |
{ |
1374 | 0 | throw new PluginConfigurationException( mojoDescriptor.getPluginDescriptor(), |
1375 | |
"A required class was missing during mojo configuration: " + e.getMessage(), e ); |
1376 | |
} |
1377 | 0 | catch ( LinkageError e ) |
1378 | |
{ |
1379 | 0 | if ( getLogger().isFatalErrorEnabled() ) |
1380 | |
{ |
1381 | 0 | getLogger().fatalError( |
1382 | |
configurator.getClass().getName() + "#configureComponent(...) caused a linkage error (" |
1383 | |
+ e.getClass().getName() + ") and may be out-of-date. Check the realms:" ); |
1384 | |
|
1385 | 0 | ClassRealm pluginRealm = mojoDescriptor.getPluginDescriptor().getClassRealm(); |
1386 | 0 | StringBuffer sb = new StringBuffer(); |
1387 | 0 | sb.append( "Plugin realm = " + pluginRealm.getId() ).append( '\n' ); |
1388 | 0 | for ( int i = 0; i < pluginRealm.getConstituents().length; i++ ) |
1389 | |
{ |
1390 | 0 | sb.append( "urls[" + i + "] = " + pluginRealm.getConstituents()[i] ); |
1391 | 0 | if ( i != ( pluginRealm.getConstituents().length - 1 ) ) |
1392 | |
{ |
1393 | 0 | sb.append( '\n' ); |
1394 | |
} |
1395 | |
} |
1396 | 0 | getLogger().fatalError( sb.toString() ); |
1397 | |
|
1398 | 0 | ClassRealm containerRealm = container.getContainerRealm(); |
1399 | 0 | sb = new StringBuffer(); |
1400 | 0 | sb.append( "Container realm = " + containerRealm.getId() ).append( '\n' ); |
1401 | 0 | for ( int i = 0; i < containerRealm.getConstituents().length; i++ ) |
1402 | |
{ |
1403 | 0 | sb.append( "urls[" + i + "] = " + containerRealm.getConstituents()[i] ); |
1404 | 0 | if ( i != ( containerRealm.getConstituents().length - 1 ) ) |
1405 | |
{ |
1406 | 0 | sb.append( '\n' ); |
1407 | |
} |
1408 | |
} |
1409 | 0 | getLogger().fatalError( sb.toString() ); |
1410 | |
} |
1411 | |
|
1412 | 0 | throw new PluginConfigurationException( mojoDescriptor.getPluginDescriptor(), |
1413 | |
e.getClass().getName() + ": " + e.getMessage(), e ); |
1414 | |
} |
1415 | |
finally |
1416 | |
{ |
1417 | 0 | if ( configurator != null ) |
1418 | |
{ |
1419 | |
try |
1420 | |
{ |
1421 | 0 | pluginContainer.release( configurator ); |
1422 | |
} |
1423 | 0 | catch ( ComponentLifecycleException e ) |
1424 | |
{ |
1425 | 0 | getLogger().debug( "Failed to release plugin container - ignoring." ); |
1426 | 0 | } |
1427 | |
} |
1428 | |
} |
1429 | 0 | } |
1430 | |
|
1431 | |
public static String createPluginParameterRequiredMessage( MojoDescriptor mojo, |
1432 | |
Parameter parameter, |
1433 | |
String expression ) |
1434 | |
{ |
1435 | 0 | StringBuffer message = new StringBuffer(); |
1436 | |
|
1437 | 0 | message.append( "The '" ); |
1438 | 0 | message.append( parameter.getName() ); |
1439 | 0 | message.append( "' parameter is required for the execution of the " ); |
1440 | 0 | message.append( mojo.getFullGoalName() ); |
1441 | 0 | message.append( " mojo and cannot be null." ); |
1442 | 0 | if ( expression != null ) |
1443 | |
{ |
1444 | 0 | message.append( " The retrieval expression was: " ).append( expression ); |
1445 | |
} |
1446 | |
|
1447 | 0 | return message.toString(); |
1448 | |
} |
1449 | |
|
1450 | |
|
1451 | |
|
1452 | |
|
1453 | |
|
1454 | |
public void contextualize( Context context ) |
1455 | |
throws ContextException |
1456 | |
{ |
1457 | 0 | container = (PlexusContainer) context.get( PlexusConstants.PLEXUS_KEY ); |
1458 | |
|
1459 | 0 | mojoLogger = new DefaultLog( container.getLoggerManager().getLoggerForComponent( Mojo.ROLE ) ); |
1460 | 0 | } |
1461 | |
|
1462 | |
public void initialize() |
1463 | |
{ |
1464 | 0 | artifactFilter = MavenArtifactFilterManager.createStandardFilter(); |
1465 | 0 | } |
1466 | |
|
1467 | |
|
1468 | |
|
1469 | |
|
1470 | |
|
1471 | |
private void resolveTransitiveDependencies( MavenSession context, |
1472 | |
ArtifactResolver artifactResolver, |
1473 | |
String scope, |
1474 | |
ArtifactFactory artifactFactory, |
1475 | |
MavenProject project, boolean isAggregator ) |
1476 | |
throws ArtifactResolutionException, ArtifactNotFoundException, InvalidDependencyVersionException |
1477 | |
{ |
1478 | 0 | ArtifactFilter filter = new ScopeArtifactFilter( scope ); |
1479 | |
|
1480 | |
|
1481 | 0 | Artifact artifact = artifactFactory.createBuildArtifact( project.getGroupId(), project.getArtifactId(), |
1482 | |
project.getVersion(), project.getPackaging() ); |
1483 | |
|
1484 | |
|
1485 | |
|
1486 | |
|
1487 | 0 | if ( project.getDependencyArtifacts() == null ) |
1488 | |
{ |
1489 | 0 | project.setDependencyArtifacts( project.createArtifacts( artifactFactory, null, null ) ); |
1490 | |
} |
1491 | |
else |
1492 | |
{ |
1493 | 0 | project.resolveActiveArtifacts(); |
1494 | |
} |
1495 | |
|
1496 | |
Set resolvedArtifacts; |
1497 | |
try |
1498 | |
{ |
1499 | 0 | ArtifactResolutionResult result = artifactResolver.resolveTransitively( project.getDependencyArtifacts(), |
1500 | |
artifact, |
1501 | |
project.getManagedVersionMap(), |
1502 | |
context.getLocalRepository(), |
1503 | |
project.getRemoteArtifactRepositories(), |
1504 | |
artifactMetadataSource, filter ); |
1505 | 0 | resolvedArtifacts = result.getArtifacts(); |
1506 | |
} |
1507 | 0 | catch (MultipleArtifactsNotFoundException me) |
1508 | |
{ |
1509 | |
|
1510 | |
|
1511 | |
|
1512 | 0 | if (isAggregator && checkMissingArtifactsInReactor( context.getSortedProjects(), me.getMissingArtifacts() )) |
1513 | |
{ |
1514 | 0 | resolvedArtifacts = new HashSet(me.getResolvedArtifacts()); |
1515 | |
} |
1516 | |
else |
1517 | |
{ |
1518 | |
|
1519 | 0 | throw me; |
1520 | |
} |
1521 | 0 | } |
1522 | 0 | project.setArtifacts( resolvedArtifacts ); |
1523 | 0 | } |
1524 | |
|
1525 | |
|
1526 | |
|
1527 | |
|
1528 | |
|
1529 | |
|
1530 | |
|
1531 | |
|
1532 | |
|
1533 | |
|
1534 | |
private boolean checkMissingArtifactsInReactor(Collection projects, Collection missing) |
1535 | |
{ |
1536 | 0 | Collection foundInReactor = new HashSet(); |
1537 | 0 | Iterator iter = missing.iterator(); |
1538 | 0 | while (iter.hasNext()) |
1539 | |
{ |
1540 | 0 | Artifact mArtifact = (Artifact) iter.next(); |
1541 | 0 | Iterator pIter = projects.iterator(); |
1542 | 0 | while (pIter.hasNext()) |
1543 | |
{ |
1544 | 0 | MavenProject p = (MavenProject) pIter.next(); |
1545 | 0 | if (p.getArtifactId().equals( mArtifact.getArtifactId()) && |
1546 | |
p.getGroupId().equals( mArtifact.getGroupId()) && |
1547 | |
p.getVersion().equals( mArtifact.getVersion())) |
1548 | |
{ |
1549 | |
|
1550 | |
|
1551 | |
|
1552 | 0 | getLogger().warn( "The dependency: "+ p.getId()+" can't be resolved but has been found in the reactor.\nThis dependency has been excluded from the plugin execution. You should rerun this mojo after executing mvn install.\n" ); |
1553 | |
|
1554 | |
|
1555 | 0 | foundInReactor.add( p ); |
1556 | 0 | break; |
1557 | |
} |
1558 | 0 | } |
1559 | 0 | } |
1560 | |
|
1561 | |
|
1562 | 0 | return foundInReactor.size() == missing.size(); |
1563 | |
} |
1564 | |
|
1565 | |
|
1566 | |
|
1567 | |
|
1568 | |
|
1569 | |
|
1570 | |
private void downloadDependencies( MavenProject project, |
1571 | |
MavenSession context, |
1572 | |
ArtifactResolver artifactResolver ) |
1573 | |
throws ArtifactResolutionException, ArtifactNotFoundException |
1574 | |
{ |
1575 | 0 | ArtifactRepository localRepository = context.getLocalRepository(); |
1576 | 0 | List remoteArtifactRepositories = project.getRemoteArtifactRepositories(); |
1577 | |
|
1578 | 0 | for ( Iterator it = project.getArtifacts().iterator(); it.hasNext(); ) |
1579 | |
{ |
1580 | 0 | Artifact artifact = (Artifact) it.next(); |
1581 | |
|
1582 | 0 | artifactResolver.resolve( artifact, remoteArtifactRepositories, localRepository ); |
1583 | 0 | } |
1584 | 0 | } |
1585 | |
|
1586 | |
public Object getPluginComponent( Plugin plugin, |
1587 | |
String role, |
1588 | |
String roleHint ) |
1589 | |
throws PluginManagerException, ComponentLookupException |
1590 | |
{ |
1591 | 0 | PluginDescriptor pluginDescriptor = pluginCollector.getPluginDescriptor( plugin ); |
1592 | |
|
1593 | 0 | PlexusContainer pluginContainer = getPluginContainer( pluginDescriptor ); |
1594 | |
|
1595 | 0 | return pluginContainer.lookup( role, roleHint ); |
1596 | |
} |
1597 | |
|
1598 | |
@SuppressWarnings( "unchecked" ) |
1599 | |
public Map getPluginComponents( Plugin plugin, |
1600 | |
String role ) |
1601 | |
throws ComponentLookupException, PluginManagerException |
1602 | |
{ |
1603 | 0 | PluginDescriptor pluginDescriptor = pluginCollector.getPluginDescriptor( plugin ); |
1604 | |
|
1605 | 0 | PlexusContainer pluginContainer = getPluginContainer( pluginDescriptor ); |
1606 | |
|
1607 | 0 | Set<String> pluginHints = findChildComponentHints( role, container, pluginContainer ); |
1608 | 0 | Map<String, Object> components = new HashMap<String, Object>( pluginHints.size() ); |
1609 | 0 | for ( String hint : pluginHints ) |
1610 | |
{ |
1611 | 0 | getLogger().debug( "Looking up plugin component: " + role + " with hint: " + hint ); |
1612 | 0 | components.put( hint, pluginContainer.lookup( role, hint ) ); |
1613 | |
} |
1614 | |
|
1615 | 0 | return components; |
1616 | |
} |
1617 | |
|
1618 | |
|
1619 | |
|
1620 | |
|
1621 | |
public PluginDescriptor loadPluginFully( Plugin plugin, MavenProject project, MavenSession session ) |
1622 | |
throws ArtifactResolutionException, PluginVersionResolutionException, ArtifactNotFoundException, |
1623 | |
InvalidVersionSpecificationException, InvalidPluginException, PluginManagerException, PluginNotFoundException, |
1624 | |
PluginVersionNotFoundException |
1625 | |
{ |
1626 | 0 | PluginDescriptor pd = verifyPlugin( plugin, project, session.getSettings(), session.getLocalRepository() ); |
1627 | |
|
1628 | 0 | PlexusContainer pluginContainer = getPluginContainer( pd ); |
1629 | 0 | ensurePluginContainerIsComplete( pd, pluginContainer, project, session ); |
1630 | |
|
1631 | 0 | return pd; |
1632 | |
} |
1633 | |
|
1634 | |
|
1635 | |
|
1636 | |
|
1637 | |
public PluginDescriptor loadPluginDescriptor( Plugin plugin, MavenProject project, MavenSession session ) |
1638 | |
throws ArtifactResolutionException, PluginVersionResolutionException, ArtifactNotFoundException, |
1639 | |
InvalidVersionSpecificationException, InvalidPluginException, PluginManagerException, PluginNotFoundException, |
1640 | |
PluginVersionNotFoundException |
1641 | |
{ |
1642 | 0 | return verifyPlugin( plugin, project, session.getSettings(), session.getLocalRepository() ); |
1643 | |
} |
1644 | |
} |