Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.atlassian.maven.plugin.clover.internal.lifecycle.Maven2LifecycleAnalyzer Maven / Gradle / Ivy
package com.atlassian.maven.plugin.clover.internal.lifecycle;
import com.atlassian.clover.api.CloverException;
import com.atlassian.clover.util.ReflectionUtils;
import com.google.common.collect.Sets;
import org.apache.maven.execution.MavenSession;
import org.apache.maven.lifecycle.Lifecycle;
import org.apache.maven.lifecycle.LifecycleExecutor;
import org.apache.maven.plugin.MojoExecution;
import org.apache.maven.project.MavenProject;
import org.jetbrains.annotations.NotNull;
import java.lang.reflect.InvocationTargetException;
import java.util.List;
import java.util.Map;
import java.util.Set;
public class Maven2LifecycleAnalyzer extends MavenLifecycleAnalyzer {
public Maven2LifecycleAnalyzer(@NotNull final LifecycleExecutor lifecycleExecutor,
@NotNull final MavenProject mavenProject,
@NotNull final MavenSession mavenSession) {
super(lifecycleExecutor, mavenProject, mavenSession);
}
@Override
public boolean isCompatibleVersion() {
return isMaven2();
}
@Override
public Set getPhasesToBeExecuted() throws CloverException {
try {
return findPhasesToBeExecutedInMaven2();
} catch (NoSuchMethodException ex) {
throw new CloverException(ex);
} catch (InvocationTargetException ex) {
throw new CloverException(ex);
} catch (IllegalAccessException ex) {
throw new CloverException(ex);
}
}
protected boolean isMaven2() {
try {
// test that all methods we need to call are avialable
lifecycleExecutor.getClass().getMethod("getPhaseToLifecycleMap");
lifecycleExecutor.getClass().getDeclaredMethod("getLifecycleForPhase",
String.class);
lifecycleExecutor.getClass().getDeclaredMethod("constructLifecycleMappings",
MavenSession.class, String.class, MavenProject.class, Lifecycle.class);
lifecycleExecutor.getClass().getDeclaredMethod("processGoalChain",
String.class, Map.class, Lifecycle.class);
// passed, seems to be Maven 2
return true;
} catch (NoSuchMethodException e) {
return false;
}
}
@NotNull
protected Set findPhasesToBeExecutedInMaven2()
throws NoSuchMethodException, IllegalAccessException, InvocationTargetException {
final Set allPhasesForAllTasks = Sets.newHashSet();
// Based on analysis of Maven's DefaultLifecycleExecutor
// mavenSession.getGoals() returns list of goals/phases defined in command line, which are called tasks
for (Object taskObj : mavenSession.getGoals()) {
final String task = taskObj.toString();
final Set allPhasesForTask;
// every task may be a build phase
if (lifecycleExecutor_getPhaseToLifecycleMap(lifecycleExecutor).containsKey(task)) {
// in such case find it's build life cycle and all goals required to run
Lifecycle lifecycle = lifecycleExecutor_getLifecycleForPhase(lifecycleExecutor, task);
Map> lifecycleMappings = lifecycleExecutor_constructLifecycleMappings(
lifecycleExecutor, mavenSession, task, mavenProject, lifecycle);
allPhasesForTask = getPhasesFromProcessGoalChain(task, lifecycleMappings, lifecycle);
} else {
// ... or is just a single goal; in such case, there's no need to find phases
allPhasesForTask = Sets.newHashSet();
}
// collect all goals
allPhasesForAllTasks.addAll(allPhasesForTask);
}
return allPhasesForAllTasks;
}
private Set getPhasesFromProcessGoalChain(String task,
Map> lifecycleMappings,
Lifecycle lifecycle) {
final List mojoGoals = lifecycleExecutor_processGoalChain(lifecycleExecutor,
task, lifecycleMappings, lifecycle);
final Set phases = Sets.newHashSet();
if (mojoGoals != null) {
for (MojoExecution mojoExecution : mojoGoals) {
phases.addAll(getPhasesFromMojoExecution(mojoExecution));
}
}
return phases;
}
// calling methods via reflections as Maven 2 and Maven 3 have different APIs
private Map lifecycleExecutor_getPhaseToLifecycleMap(
@NotNull final LifecycleExecutor lifecycleExecutor)
throws NoSuchMethodException, IllegalAccessException, InvocationTargetException {
// return lifecycleExecutor.getPhaseToLifecycleMap()
return (Map) ReflectionUtils.invokeVirtualImplicit("getPhaseToLifecycleMap", lifecycleExecutor);
}
private Map> lifecycleExecutor_constructLifecycleMappings(
@NotNull final LifecycleExecutor lifecycleExecutor,
MavenSession mavenSession, String task, MavenProject mavenProject, Lifecycle lifecycle)
throws NoSuchMethodException, IllegalAccessException, InvocationTargetException {
// return lifecycleExecutor.constructLifecycleMappings(...)
return (Map>) ReflectionUtils.invokeVirtualImplicit(
"constructLifecycleMappings", lifecycleExecutor,
mavenSession, task, mavenProject, lifecycle);
}
private Lifecycle lifecycleExecutor_getLifecycleForPhase(
@NotNull final LifecycleExecutor lifecycleExecutor,
String task)
throws NoSuchMethodException, IllegalAccessException, InvocationTargetException {
// return lifecycleExecutor.getLifecycleForPhase(task)
return (Lifecycle) ReflectionUtils.invokeVirtualImplicit("getLifecycleForPhase", lifecycleExecutor, task);
}
private List lifecycleExecutor_processGoalChain(
@NotNull final LifecycleExecutor lifecycleExecutor,
String task,
Map> lifecycleMappings,
Lifecycle lifecycle) {
try {
return (List) ReflectionUtils.invokeVirtualImplicit("processGoalChain", lifecycleExecutor,
task, lifecycleMappings, lifecycle);
} catch (Exception e) {
return null;
}
}
}