o collapsing more of the project builder, trying to turn it back into one component -- we have the old and the new with the old wrapper the new -- so that I can have an interface for compatibility and then all our new stuff in another component.

git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@727299 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Jason van Zyl 2008-12-17 06:27:16 +00:00
parent 4dfe959d63
commit 7d3040a73e
5 changed files with 24 additions and 129 deletions

View File

@ -566,7 +566,7 @@ public class DefaultPluginManager
List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>(); List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>();
interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( session.getProjectBuilderConfiguration().getExecutionProperties(), interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( session.getProjectBuilderConfiguration().getExecutionProperties(),
PomInterpolatorTag.SYSTEM_PROPERTIES.name())); PomInterpolatorTag.EXECUTION_PROPERTIES.name()));
interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( session.getProjectBuilderConfiguration().getUserProperties(), interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( session.getProjectBuilderConfiguration().getUserProperties(),
PomInterpolatorTag.USER_PROPERTIES.name())); PomInterpolatorTag.USER_PROPERTIES.name()));

View File

@ -71,12 +71,12 @@ public final class MavenDependencyProcessor
List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>(); List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>();
interpolatorProperties.add( new InterpolatorProperty( "${mavenVersion}", "3.0-SNAPSHOT", interpolatorProperties.add( new InterpolatorProperty( "${mavenVersion}", "3.0-SNAPSHOT",
PomInterpolatorTag.SYSTEM_PROPERTIES.name() ) ); PomInterpolatorTag.EXECUTION_PROPERTIES.name() ) );
if ( system != null ) if ( system != null )
{ {
interpolatorProperties.addAll( interpolatorProperties.addAll(
InterpolatorProperty.toInterpolatorProperties( system, PomInterpolatorTag.SYSTEM_PROPERTIES.name() ) ); InterpolatorProperty.toInterpolatorProperties( system, PomInterpolatorTag.EXECUTION_PROPERTIES.name() ) );
} }
if ( user != null ) if ( user != null )
{ {

View File

@ -8,7 +8,5 @@ public enum PomInterpolatorTag
PROJECT_PROPERTIES, PROJECT_PROPERTIES,
SYSTEM_PROPERTIES EXECUTION_PROPERTIES
} }

View File

@ -22,9 +22,6 @@ package org.apache.maven.project;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.io.Reader; import java.io.Reader;
import java.io.StringReader;
import java.io.StringWriter;
import java.net.URL;
import java.text.SimpleDateFormat; import java.text.SimpleDateFormat;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
@ -46,7 +43,6 @@ import org.apache.maven.model.Build;
import org.apache.maven.model.Model; import org.apache.maven.model.Model;
import org.apache.maven.model.Profile; import org.apache.maven.model.Profile;
import org.apache.maven.model.io.xpp3.MavenXpp3Reader; import org.apache.maven.model.io.xpp3.MavenXpp3Reader;
import org.apache.maven.model.io.xpp3.MavenXpp3Writer;
import org.apache.maven.profiles.MavenProfilesBuilder; import org.apache.maven.profiles.MavenProfilesBuilder;
import org.apache.maven.profiles.ProfileManager; import org.apache.maven.profiles.ProfileManager;
import org.apache.maven.profiles.activation.DefaultProfileActivationContext; import org.apache.maven.profiles.activation.DefaultProfileActivationContext;
@ -55,7 +51,6 @@ import org.apache.maven.profiles.activation.ProfileActivationException;
import org.apache.maven.profiles.build.ProfileAdvisor; import org.apache.maven.profiles.build.ProfileAdvisor;
import org.apache.maven.project.artifact.InvalidDependencyVersionException; import org.apache.maven.project.artifact.InvalidDependencyVersionException;
import org.apache.maven.project.builder.DefaultPomArtifactResolver; import org.apache.maven.project.builder.DefaultPomArtifactResolver;
import org.apache.maven.project.builder.Interpolator;
import org.apache.maven.project.builder.PomArtifactResolver; import org.apache.maven.project.builder.PomArtifactResolver;
import org.apache.maven.project.builder.PomInterpolatorTag; import org.apache.maven.project.builder.PomInterpolatorTag;
import org.apache.maven.project.builder.ProjectBuilder; import org.apache.maven.project.builder.ProjectBuilder;
@ -218,98 +213,34 @@ public class DefaultMavenProjectBuilder
/** /**
* This is used for pom-less execution like running archetype:generate. * This is used for pom-less execution like running archetype:generate.
*
* I am taking out the profile handling and the interpolation of the base directory until we spec
* this out properly.
*/ */
public MavenProject buildStandaloneSuperProject( ProjectBuilderConfiguration config ) public MavenProject buildStandaloneSuperProject( ProjectBuilderConfiguration config )
throws ProjectBuildingException throws ProjectBuildingException
{ {
Model superModel = getSuperModel(); Model superModel = getSuperModel();
ProfileManager profileManager = config.getGlobalProfileManager(); MavenProject project = null;
List activeProfiles = new ArrayList();
if ( profileManager != null )
{
List activated = profileAdvisor.applyActivatedProfiles( superModel, null, false,
profileManager.getProfileActivationContext() );
if ( !activated.isEmpty() )
{
activeProfiles.addAll( activated );
}
activated = profileAdvisor.applyActivatedExternalProfiles( superModel, null, profileManager );
if ( !activated.isEmpty() )
{
activeProfiles.addAll( activated );
}
}
List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>();
interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( config.getExecutionProperties(),
PomInterpolatorTag.SYSTEM_PROPERTIES.name()));
interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( config.getUserProperties(),
PomInterpolatorTag.USER_PROPERTIES.name()));
if(config.getBuildStartTime() != null)
{
interpolatorProperties.add(new InterpolatorProperty("${build.timestamp}",
new SimpleDateFormat("yyyyMMdd-hhmm").format( config.getBuildStartTime() ),
PomInterpolatorTag.PROJECT_PROPERTIES.name()));
}
File basedir = null;
for(InterpolatorProperty ip : interpolatorProperties )
{
if(ip.getKey().equals("${basedir}"))
{
basedir = new File(ip.getValue());
break;
}
}
if(basedir == null)
{
String bd = System.getProperty("basedir");
if( bd != null )
{
basedir = new File(bd);
}
}
try
{
superModel = Interpolator.interpolateModel(superModel, interpolatorProperties, basedir );
}
catch (IOException e)
{
throw new ProjectBuildingException(STANDALONE_SUPERPOM_GROUPID + ":" + STANDALONE_SUPERPOM_ARTIFACTID, "Interpolation failure:", e);
}
MavenProject project;
try try
{ {
project = new MavenProject( superModel, artifactFactory, mavenTools, this, config ); project = new MavenProject( superModel, artifactFactory, mavenTools, this, config );
} }
catch ( InvalidRepositoryException e ) catch ( InvalidRepositoryException e )
{ {
throw new ProjectBuildingException( STANDALONE_SUPERPOM_GROUPID + ":" + STANDALONE_SUPERPOM_ARTIFACTID, // Not going to happen.
"Maven super-POM contains an invalid repository!", e );
} }
getLogger().debug( "Activated the following profiles for standalone super-pom: " + activeProfiles );
try try
{ {
project = constructMavenProjectFromModel( project.getModel(), null, null, config );
project.setActiveProfiles( activeProfiles );
project.setRemoteArtifactRepositories( mavenTools.buildArtifactRepositories( superModel.getRepositories() ) ); project.setRemoteArtifactRepositories( mavenTools.buildArtifactRepositories( superModel.getRepositories() ) );
project.setPluginArtifactRepositories( mavenTools.buildArtifactRepositories( superModel.getRepositories() ) ); project.setPluginArtifactRepositories( mavenTools.buildArtifactRepositories( superModel.getRepositories() ) );
} }
catch ( InvalidRepositoryException e ) catch ( InvalidRepositoryException e )
{ {
throw new ProjectBuildingException( STANDALONE_SUPERPOM_GROUPID + ":" + STANDALONE_SUPERPOM_ARTIFACTID, // Not going to happen.
"Maven super-POM contains an invalid repository!", e );
} }
project.setExecutionRoot( true ); project.setExecutionRoot( true );
@ -391,7 +322,16 @@ public class DefaultMavenProjectBuilder
try try
{ {
project = constructMavenProjectFromModel( model, projectDescriptor, parentDescriptor, config ); project = new MavenProject( model, artifactFactory, mavenTools, this, config );
validateModel( model, projectDescriptor );
Artifact projectArtifact = artifactFactory.createBuildArtifact( project.getGroupId(), project.getArtifactId(),
project.getVersion(), project.getPackaging() );
project.setArtifact( projectArtifact );
project.setParentFile( parentDescriptor );
} }
catch ( InvalidRepositoryException e ) catch ( InvalidRepositoryException e )
{ {
@ -409,22 +349,6 @@ public class DefaultMavenProjectBuilder
return project; return project;
} }
private MavenProject constructMavenProjectFromModel( Model model, File pomFile, File parentFile,
ProjectBuilderConfiguration config )
throws ProjectBuildingException, InvalidRepositoryException
{
MavenProject project = new MavenProject( model, artifactFactory, mavenTools, this, config );
validateModel( model, pomFile );
Artifact projectArtifact = artifactFactory.createBuildArtifact( project.getGroupId(), project.getArtifactId(),
project.getVersion(), project.getPackaging() );
project.setArtifact( projectArtifact );
project.setParentFile( parentFile );
return project;
}
private MavenProject superProject; private MavenProject superProject;
private MavenProject getSuperProject( ProjectBuilderConfiguration config, File projectDescriptor ) private MavenProject getSuperProject( ProjectBuilderConfiguration config, File projectDescriptor )
@ -489,7 +413,7 @@ public class DefaultMavenProjectBuilder
List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>(); List<InterpolatorProperty> interpolatorProperties = new ArrayList<InterpolatorProperty>();
interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( config.getExecutionProperties(), interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( config.getExecutionProperties(),
PomInterpolatorTag.SYSTEM_PROPERTIES.name())); PomInterpolatorTag.EXECUTION_PROPERTIES.name()));
interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( config.getUserProperties(), interpolatorProperties.addAll( InterpolatorProperty.toInterpolatorProperties( config.getUserProperties(),
PomInterpolatorTag.USER_PROPERTIES.name())); PomInterpolatorTag.USER_PROPERTIES.name()));
@ -501,14 +425,14 @@ public class DefaultMavenProjectBuilder
PomInterpolatorTag.PROJECT_PROPERTIES.name())); PomInterpolatorTag.PROJECT_PROPERTIES.name()));
} }
interpolatorProperties.add(new InterpolatorProperty("${mavenVersion}", MavenProjectBuilder.STANDALONE_SUPERPOM_VERSION, PomInterpolatorTag.SYSTEM_PROPERTIES.name())); interpolatorProperties.add(new InterpolatorProperty("${mavenVersion}", MavenProjectBuilder.STANDALONE_SUPERPOM_VERSION, PomInterpolatorTag.EXECUTION_PROPERTIES.name()));
MavenProject mavenProject; MavenProject mavenProject;
try try
{ {
mavenProject = projectBuilder.buildFromLocalPath( projectDescriptor, mavenProject = projectBuilder.buildFromLocalPath( projectDescriptor,
Arrays.asList( getSuperProject( config, projectDescriptor ).getModel() ), Arrays.asList( getSuperModel() ),
interpolatorProperties, interpolatorProperties,
resolver, resolver,
config ); config );

View File

@ -41,33 +41,6 @@ public class SuperPomProjectBuilderTest
projectBuilder = lookup( MavenProjectBuilder.class ); projectBuilder = lookup( MavenProjectBuilder.class );
} }
public void testStandaloneSuperPomContainsInjectedExternalProfileRepositories()
throws Exception
{
Profile profile = new Profile();
profile.setId( "test-profile" );
Repository repo = new Repository();
repo.setId( "test" );
repo.setUrl( "http://www.nowhere.com" );
profile.addRepository( repo );
ProfileManager pm = new DefaultProfileManager( getContainer(), new DefaultProfileActivationContext( new Properties(), true ) );
pm.addProfile( profile );
pm.explicitlyActivate( profile.getId() );
ProjectBuilderConfiguration pbc = new DefaultProjectBuilderConfiguration();
pbc.setGlobalProfileManager( pm );
MavenProject project = projectBuilder.buildStandaloneSuperProject( pbc );
assertRepository( repo.getId(), project.getRepositories() );
assertRepository( repo.getId(), project.getPluginRepositories() );
assertArtifactRepository( repo.getId(), project.getRemoteArtifactRepositories() );
assertArtifactRepository( repo.getId(), project.getPluginArtifactRepositories() );
}
public void testStandaloneSuperPomContainsCentralRepo() public void testStandaloneSuperPomContainsCentralRepo()
throws ProjectBuildingException throws ProjectBuildingException
{ {