mirror of https://github.com/apache/maven.git
o scrub of the settings building, was able to reduce to the need of the build context and use the execution request
directly. eventually i will get it to be the session, along with the profile tools, then all the tools can also share a common interpolator, which can then be shared by other components instead of having 5 interpolators lying around causing a great deal of inconsistency. git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@573494 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
28ac7d65cb
commit
e9b6657f4c
|
@ -32,7 +32,7 @@ import java.util.List;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
|
* @author Jason van Zyl
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
public class DefaultMavenExecutionRequest
|
public class DefaultMavenExecutionRequest
|
||||||
|
@ -60,6 +60,16 @@ public class DefaultMavenExecutionRequest
|
||||||
|
|
||||||
private boolean isProjectPresent = true;
|
private boolean isProjectPresent = true;
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// We need to allow per execution user and global settings as the embedder
|
||||||
|
// might be running in a mode where its executing many threads with totally
|
||||||
|
// different settings.
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
private File userSettingsFile;
|
||||||
|
|
||||||
|
private File globalSettingsFile;
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// Request
|
// Request
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@ -531,4 +541,30 @@ public class DefaultMavenExecutionRequest
|
||||||
|
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Settings files
|
||||||
|
|
||||||
|
public File getUserSettingsFile()
|
||||||
|
{
|
||||||
|
return userSettingsFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MavenExecutionRequest setUserSettingsFile( File userSettingsFile )
|
||||||
|
{
|
||||||
|
this.userSettingsFile = userSettingsFile;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public File getGlobalSettingsFile()
|
||||||
|
{
|
||||||
|
return globalSettingsFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
public MavenExecutionRequest setGlobalSettingsFile( File globalSettingsFile )
|
||||||
|
{
|
||||||
|
this.globalSettingsFile = globalSettingsFile;
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -189,4 +189,10 @@ public interface MavenExecutionRequest
|
||||||
|
|
||||||
boolean isProjectPresent();
|
boolean isProjectPresent();
|
||||||
MavenExecutionRequest setProjectPresent( boolean isProjectPresent );
|
MavenExecutionRequest setProjectPresent( boolean isProjectPresent );
|
||||||
|
|
||||||
|
File getUserSettingsFile();
|
||||||
|
MavenExecutionRequest setUserSettingsFile( File userSettingsFile );
|
||||||
|
|
||||||
|
File getGlobalSettingsFile();
|
||||||
|
MavenExecutionRequest setGlobalSettingsFile( File globalSettingsFile );
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,8 +19,7 @@ package org.apache.maven.settings;
|
||||||
* under the License.
|
* under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.maven.context.BuildContextManager;
|
import org.apache.maven.execution.MavenExecutionRequest;
|
||||||
import org.apache.maven.context.SystemBuildContext;
|
|
||||||
import org.apache.maven.settings.io.xpp3.SettingsXpp3Reader;
|
import org.apache.maven.settings.io.xpp3.SettingsXpp3Reader;
|
||||||
import org.apache.maven.settings.io.xpp3.SettingsXpp3Writer;
|
import org.apache.maven.settings.io.xpp3.SettingsXpp3Writer;
|
||||||
import org.apache.maven.settings.validation.SettingsValidationResult;
|
import org.apache.maven.settings.validation.SettingsValidationResult;
|
||||||
|
@ -49,18 +48,18 @@ public class DefaultMavenSettingsBuilder
|
||||||
{
|
{
|
||||||
private SettingsValidator validator;
|
private SettingsValidator validator;
|
||||||
|
|
||||||
private BuildContextManager manager;
|
/** @since 2.1 */
|
||||||
|
public Settings buildSettings( MavenExecutionRequest request )
|
||||||
/**
|
|
||||||
* @since 2.1
|
|
||||||
*/
|
|
||||||
public Settings buildSettings( File userSettingsFile, File globalSettingsFile )
|
|
||||||
throws IOException, XmlPullParserException
|
throws IOException, XmlPullParserException
|
||||||
{
|
{
|
||||||
|
File userSettingsFile = request.getUserSettingsFile();
|
||||||
|
|
||||||
|
File globalSettingsFile = request.getGlobalSettingsFile();
|
||||||
|
|
||||||
if ( ( globalSettingsFile == null ) && ( userSettingsFile == null ) )
|
if ( ( globalSettingsFile == null ) && ( userSettingsFile == null ) )
|
||||||
{
|
{
|
||||||
getLogger().debug(
|
getLogger().debug(
|
||||||
"No settings files provided, and default locations are disabled for this request. Returning empty Settings instance." );
|
"No settings files provided, and default locations are disabled for this request. Returning empty Settings instance." );
|
||||||
return new Settings();
|
return new Settings();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,37 +81,46 @@ public class DefaultMavenSettingsBuilder
|
||||||
userSettings = new Settings();
|
userSettings = new Settings();
|
||||||
}
|
}
|
||||||
|
|
||||||
validateSettings( globalSettings, globalSettingsFile );
|
validateSettings(
|
||||||
|
globalSettings,
|
||||||
|
globalSettingsFile );
|
||||||
|
|
||||||
validateSettings( userSettings, userSettingsFile );
|
validateSettings(
|
||||||
|
userSettings,
|
||||||
|
userSettingsFile );
|
||||||
|
|
||||||
SettingsUtils.merge( userSettings, globalSettings, TrackableBase.GLOBAL_LEVEL );
|
SettingsUtils.merge(
|
||||||
|
userSettings,
|
||||||
|
globalSettings,
|
||||||
|
TrackableBase.GLOBAL_LEVEL );
|
||||||
|
|
||||||
userSettings = interpolate( userSettings );
|
userSettings = interpolate( userSettings, request );
|
||||||
|
|
||||||
return userSettings;
|
return userSettings;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Settings interpolate( Settings settings )
|
private Settings interpolate( Settings settings, MavenExecutionRequest request )
|
||||||
throws IOException, XmlPullParserException
|
throws IOException, XmlPullParserException
|
||||||
{
|
{
|
||||||
List activeProfiles = settings.getActiveProfiles();
|
List activeProfiles = settings.getActiveProfiles();
|
||||||
|
|
||||||
StringWriter writer = new StringWriter();
|
StringWriter writer = new StringWriter();
|
||||||
|
|
||||||
new SettingsXpp3Writer().write( writer, settings );
|
new SettingsXpp3Writer().write(
|
||||||
|
writer,
|
||||||
|
settings );
|
||||||
|
|
||||||
String serializedSettings = writer.toString();
|
String serializedSettings = writer.toString();
|
||||||
|
|
||||||
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( manager, true );
|
|
||||||
|
|
||||||
RegexBasedInterpolator interpolator = new RegexBasedInterpolator();
|
RegexBasedInterpolator interpolator = new RegexBasedInterpolator();
|
||||||
|
|
||||||
interpolator.addValueSource( new PropertiesBasedValueSource( sysContext.getSystemProperties() ) );
|
interpolator.addValueSource( new PropertiesBasedValueSource( request.getProperties() ) );
|
||||||
|
|
||||||
interpolator.addValueSource( new EnvarBasedValueSource() );
|
interpolator.addValueSource( new EnvarBasedValueSource() );
|
||||||
|
|
||||||
serializedSettings = interpolator.interpolate( serializedSettings, "settings" );
|
serializedSettings = interpolator.interpolate(
|
||||||
|
serializedSettings,
|
||||||
|
"settings" );
|
||||||
|
|
||||||
Settings result = new SettingsXpp3Reader().read( new StringReader( serializedSettings ) );
|
Settings result = new SettingsXpp3Reader().read( new StringReader( serializedSettings ) );
|
||||||
|
|
||||||
|
@ -127,52 +135,44 @@ public class DefaultMavenSettingsBuilder
|
||||||
if ( settingsFile == null )
|
if ( settingsFile == null )
|
||||||
{
|
{
|
||||||
getLogger().debug( "Settings file is null. Returning." );
|
getLogger().debug( "Settings file is null. Returning." );
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
Settings settings = null;
|
Settings settings = null;
|
||||||
|
|
||||||
if ( settingsFile.exists() && settingsFile.isFile() )
|
FileReader reader = null;
|
||||||
|
|
||||||
|
try
|
||||||
{
|
{
|
||||||
getLogger().debug( "Settings file is a proper file. Reading." );
|
reader = new FileReader( settingsFile );
|
||||||
|
|
||||||
FileReader reader = null;
|
SettingsXpp3Reader modelReader = new SettingsXpp3Reader();
|
||||||
try
|
|
||||||
{
|
|
||||||
reader = new FileReader( settingsFile );
|
|
||||||
|
|
||||||
SettingsXpp3Reader modelReader = new SettingsXpp3Reader();
|
settings = modelReader.read( reader );
|
||||||
|
}
|
||||||
|
catch ( XmlPullParserException e )
|
||||||
|
{
|
||||||
|
getLogger().error( "Failed to read settings from: " + settingsFile + ". Throwing XmlPullParserException..." );
|
||||||
|
|
||||||
settings = modelReader.read( reader );
|
throw e;
|
||||||
|
}
|
||||||
|
catch ( IOException e )
|
||||||
|
{
|
||||||
|
getLogger().error( "Failed to read settings from: " + settingsFile + ". Throwing IOException..." );
|
||||||
|
|
||||||
RuntimeInfo rtInfo = new RuntimeInfo( settings );
|
throw e;
|
||||||
|
}
|
||||||
rtInfo.addLocation( settingsFile.getAbsolutePath() );
|
finally
|
||||||
|
{
|
||||||
settings.setRuntimeInfo( rtInfo );
|
IOUtil.close( reader );
|
||||||
}
|
|
||||||
catch ( XmlPullParserException e )
|
|
||||||
{
|
|
||||||
getLogger().error( "Failed to read settings from: " + settingsFile + ". Throwing XmlPullParserException..." );
|
|
||||||
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
catch ( IOException e )
|
|
||||||
{
|
|
||||||
getLogger().error( "Failed to read settings from: " + settingsFile + ". Throwing IOException..." );
|
|
||||||
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
IOUtil.close( reader );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return settings;
|
return settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void validateSettings( Settings settings, File location )
|
private void validateSettings( Settings settings,
|
||||||
|
File location )
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
SettingsValidationResult validationResult = validator.validate( settings );
|
SettingsValidationResult validationResult = validator.validate( settings );
|
||||||
|
|
|
@ -19,34 +19,20 @@ package org.apache.maven.settings;
|
||||||
* under the License.
|
* under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
import org.apache.maven.execution.MavenExecutionRequest;
|
||||||
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
|
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builder for the user or global settings. By default, the settings files are located:
|
|
||||||
* <ul>
|
|
||||||
* <li>user settings: ${user.home}/settings.xml</li>
|
|
||||||
* <li>global settings: ${maven.home}/conf/settings.xml</li>
|
|
||||||
* </ul>
|
|
||||||
*
|
|
||||||
* @author jdcasey
|
* @author jdcasey
|
||||||
|
* @author Jason van Zyl
|
||||||
* @version $Id$
|
* @version $Id$
|
||||||
*/
|
*/
|
||||||
public interface MavenSettingsBuilder
|
public interface MavenSettingsBuilder
|
||||||
{
|
{
|
||||||
String ROLE = MavenSettingsBuilder.class.getName();
|
String ROLE = MavenSettingsBuilder.class.getName();
|
||||||
|
|
||||||
/**
|
Settings buildSettings( MavenExecutionRequest request )
|
||||||
*
|
|
||||||
* @param userSettingsFile
|
|
||||||
* @param globalSettingsFile
|
|
||||||
* @return a <code>Settings</code> object from the user and global settings file.
|
|
||||||
* @throws IOException if any
|
|
||||||
* @throws XmlPullParserException if any
|
|
||||||
* @since 2.1
|
|
||||||
*/
|
|
||||||
Settings buildSettings( File userSettingsFile, File globalSettingsFile )
|
|
||||||
throws IOException, XmlPullParserException;
|
throws IOException, XmlPullParserException;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,180 +0,0 @@
|
||||||
package org.apache.maven.settings;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Licensed to the Apache Software Foundation (ASF) under one
|
|
||||||
* or more contributor license agreements. See the NOTICE file
|
|
||||||
* distributed with this work for additional information
|
|
||||||
* regarding copyright ownership. The ASF licenses this file
|
|
||||||
* to you under the Apache License, Version 2.0 (the
|
|
||||||
* "License"); you may not use this file except in compliance
|
|
||||||
* with the License. You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing,
|
|
||||||
* software distributed under the License is distributed on an
|
|
||||||
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
||||||
* KIND, either express or implied. See the License for the
|
|
||||||
* specific language governing permissions and limitations
|
|
||||||
* under the License.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* To handle runtime informations like local repository or profiles.
|
|
||||||
*
|
|
||||||
* @version $Id$
|
|
||||||
*/
|
|
||||||
public class RuntimeInfo
|
|
||||||
{
|
|
||||||
private List locations = new ArrayList();
|
|
||||||
|
|
||||||
// using Boolean for 3VL (null for not-set, otherwise override with value)
|
|
||||||
private Boolean pluginUpdateForced;
|
|
||||||
|
|
||||||
// using Boolean for 3VL (null, true-to-all, false-to-all)
|
|
||||||
private Boolean applyToAllPluginUpdates;
|
|
||||||
|
|
||||||
// private boolean pluginRegistryActive = true;
|
|
||||||
|
|
||||||
// using Boolean for 3VL (null for not-set, otherwise override with value)
|
|
||||||
// private Boolean checkLatest;
|
|
||||||
|
|
||||||
private Map activeProfileToSourceLevel = new HashMap();
|
|
||||||
|
|
||||||
private String localRepositorySourceLevel = TrackableBase.USER_LEVEL;
|
|
||||||
|
|
||||||
private Map pluginGroupIdSourceLevels = new HashMap();
|
|
||||||
|
|
||||||
private final Settings settings;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param settings
|
|
||||||
*/
|
|
||||||
public RuntimeInfo( Settings settings )
|
|
||||||
{
|
|
||||||
this.settings = settings;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param path
|
|
||||||
*/
|
|
||||||
public void addLocation( String path )
|
|
||||||
{
|
|
||||||
this.locations.add( path );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public List getLocations()
|
|
||||||
{
|
|
||||||
return locations;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param pluginUpdateForced
|
|
||||||
*/
|
|
||||||
public void setPluginUpdateOverride( Boolean pluginUpdateForced )
|
|
||||||
{
|
|
||||||
this.pluginUpdateForced = pluginUpdateForced;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Boolean getPluginUpdateOverride()
|
|
||||||
{
|
|
||||||
return pluginUpdateForced;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public Boolean getApplyToAllPluginUpdates()
|
|
||||||
{
|
|
||||||
return applyToAllPluginUpdates;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param applyToAll
|
|
||||||
*/
|
|
||||||
public void setApplyToAllPluginUpdates( Boolean applyToAll )
|
|
||||||
{
|
|
||||||
this.applyToAllPluginUpdates = applyToAll;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param activeProfile
|
|
||||||
* @param sourceLevel
|
|
||||||
*/
|
|
||||||
public void setActiveProfileSourceLevel( String activeProfile, String sourceLevel )
|
|
||||||
{
|
|
||||||
activeProfileToSourceLevel.put( activeProfile, sourceLevel );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param activeProfile
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public String getSourceLevelForActiveProfile( String activeProfile )
|
|
||||||
{
|
|
||||||
String sourceLevel = (String) activeProfileToSourceLevel.get( activeProfile );
|
|
||||||
|
|
||||||
if ( sourceLevel != null )
|
|
||||||
{
|
|
||||||
return sourceLevel;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return settings.getSourceLevel();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param pluginGroupId
|
|
||||||
* @param sourceLevel
|
|
||||||
*/
|
|
||||||
public void setPluginGroupIdSourceLevel( String pluginGroupId, String sourceLevel )
|
|
||||||
{
|
|
||||||
pluginGroupIdSourceLevels.put( pluginGroupId, sourceLevel );
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param pluginGroupId
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public String getSourceLevelForPluginGroupId( String pluginGroupId )
|
|
||||||
{
|
|
||||||
String sourceLevel = (String) pluginGroupIdSourceLevels.get( pluginGroupId );
|
|
||||||
|
|
||||||
if ( sourceLevel != null )
|
|
||||||
{
|
|
||||||
return sourceLevel;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return settings.getSourceLevel();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param localRepoSourceLevel
|
|
||||||
*/
|
|
||||||
public void setLocalRepositorySourceLevel( String localRepoSourceLevel )
|
|
||||||
{
|
|
||||||
this.localRepositorySourceLevel = localRepoSourceLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
public String getLocalRepositorySourceLevel()
|
|
||||||
{
|
|
||||||
return localRepositorySourceLevel;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -73,27 +73,12 @@ public final class SettingsUtils
|
||||||
if ( !dominantActiveProfiles.contains( profileId ) )
|
if ( !dominantActiveProfiles.contains( profileId ) )
|
||||||
{
|
{
|
||||||
dominantActiveProfiles.add( profileId );
|
dominantActiveProfiles.add( profileId );
|
||||||
|
|
||||||
if ( dominant.getRuntimeInfo() != null )
|
|
||||||
{
|
|
||||||
dominant.getRuntimeInfo().setActiveProfileSourceLevel( profileId, recessiveSourceLevel );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( dominant.getRuntimeInfo() != null && recessive.getRuntimeInfo() != null )
|
|
||||||
{
|
|
||||||
List recessiveLocations = recessive.getRuntimeInfo().getLocations();
|
|
||||||
for ( Iterator it = recessiveLocations.iterator(); it.hasNext(); )
|
|
||||||
{
|
|
||||||
String path = (String) it.next();
|
|
||||||
|
|
||||||
dominant.getRuntimeInfo().addLocation( path );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
List dominantPluginGroupIds = dominant.getPluginGroups();
|
List dominantPluginGroupIds = dominant.getPluginGroups();
|
||||||
|
|
||||||
List recessivePluginGroupIds = recessive.getPluginGroups();
|
List recessivePluginGroupIds = recessive.getPluginGroups();
|
||||||
|
|
||||||
if ( recessivePluginGroupIds != null )
|
if ( recessivePluginGroupIds != null )
|
||||||
|
@ -111,11 +96,6 @@ public final class SettingsUtils
|
||||||
if ( !dominantPluginGroupIds.contains( pluginGroupId ) )
|
if ( !dominantPluginGroupIds.contains( pluginGroupId ) )
|
||||||
{
|
{
|
||||||
dominantPluginGroupIds.add( pluginGroupId );
|
dominantPluginGroupIds.add( pluginGroupId );
|
||||||
|
|
||||||
if ( dominant.getRuntimeInfo() != null )
|
|
||||||
{
|
|
||||||
dominant.getRuntimeInfo().setPluginGroupIdSourceLevel( pluginGroupId, recessiveSourceLevel );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -123,11 +103,6 @@ public final class SettingsUtils
|
||||||
if ( StringUtils.isEmpty( dominant.getLocalRepository() ) )
|
if ( StringUtils.isEmpty( dominant.getLocalRepository() ) )
|
||||||
{
|
{
|
||||||
dominant.setLocalRepository( recessive.getLocalRepository() );
|
dominant.setLocalRepository( recessive.getLocalRepository() );
|
||||||
|
|
||||||
if ( dominant.getRuntimeInfo() != null )
|
|
||||||
{
|
|
||||||
dominant.getRuntimeInfo().setLocalRepositorySourceLevel( recessiveSourceLevel );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
shallowMergeById( dominant.getMirrors(), recessive.getMirrors(), recessiveSourceLevel );
|
shallowMergeById( dominant.getMirrors(), recessive.getMirrors(), recessiveSourceLevel );
|
||||||
|
|
|
@ -392,18 +392,6 @@
|
||||||
|
|
||||||
return profileMap;
|
return profileMap;
|
||||||
}
|
}
|
||||||
|
|
||||||
private RuntimeInfo runtimeInfo;
|
|
||||||
|
|
||||||
public void setRuntimeInfo( RuntimeInfo runtimeInfo )
|
|
||||||
{
|
|
||||||
this.runtimeInfo = runtimeInfo;
|
|
||||||
}
|
|
||||||
|
|
||||||
public RuntimeInfo getRuntimeInfo()
|
|
||||||
{
|
|
||||||
return runtimeInfo;
|
|
||||||
}
|
|
||||||
]]>
|
]]>
|
||||||
</code>
|
</code>
|
||||||
</codeSegment>
|
</codeSegment>
|
||||||
|
|
|
@ -32,14 +32,10 @@ public class SettingsUtilsTest
|
||||||
Settings dominant = new Settings();
|
Settings dominant = new Settings();
|
||||||
dominant.addPluginGroup( "org.apache.maven.plugins" );
|
dominant.addPluginGroup( "org.apache.maven.plugins" );
|
||||||
dominant.addPluginGroup( "org.codehaus.modello" );
|
dominant.addPluginGroup( "org.codehaus.modello" );
|
||||||
|
|
||||||
dominant.setRuntimeInfo(new RuntimeInfo(dominant));
|
|
||||||
|
|
||||||
Settings recessive = new Settings();
|
Settings recessive = new Settings();
|
||||||
recessive.addPluginGroup( "org.codehaus.plexus" );
|
recessive.addPluginGroup( "org.codehaus.plexus" );
|
||||||
|
|
||||||
recessive.setRuntimeInfo(new RuntimeInfo(recessive));
|
|
||||||
|
|
||||||
SettingsUtils.merge( dominant, recessive, Settings.GLOBAL_LEVEL );
|
SettingsUtils.merge( dominant, recessive, Settings.GLOBAL_LEVEL );
|
||||||
|
|
||||||
List pluginGroups = dominant.getPluginGroups();
|
List pluginGroups = dominant.getPluginGroups();
|
||||||
|
|
|
@ -20,14 +20,12 @@ package org.apache.maven.embedder;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.maven.Maven;
|
import org.apache.maven.Maven;
|
||||||
import org.apache.maven.settings.SettingsConfigurationException;
|
|
||||||
import org.apache.maven.artifact.Artifact;
|
import org.apache.maven.artifact.Artifact;
|
||||||
import org.apache.maven.artifact.factory.ArtifactFactory;
|
import org.apache.maven.artifact.factory.ArtifactFactory;
|
||||||
import org.apache.maven.artifact.handler.ArtifactHandler;
|
import org.apache.maven.artifact.handler.ArtifactHandler;
|
||||||
import org.apache.maven.artifact.handler.manager.ArtifactHandlerManager;
|
import org.apache.maven.artifact.handler.manager.ArtifactHandlerManager;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy;
|
|
||||||
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
||||||
import org.apache.maven.artifact.resolver.ArtifactNotFoundException;
|
import org.apache.maven.artifact.resolver.ArtifactNotFoundException;
|
||||||
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
|
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
|
||||||
|
@ -58,6 +56,7 @@ import org.apache.maven.project.MavenProjectBuilder;
|
||||||
import org.apache.maven.project.MavenProjectBuildingResult;
|
import org.apache.maven.project.MavenProjectBuildingResult;
|
||||||
import org.apache.maven.project.ProjectBuildingException;
|
import org.apache.maven.project.ProjectBuildingException;
|
||||||
import org.apache.maven.settings.Settings;
|
import org.apache.maven.settings.Settings;
|
||||||
|
import org.apache.maven.settings.SettingsConfigurationException;
|
||||||
import org.apache.maven.settings.io.jdom.SettingsJDOMWriter;
|
import org.apache.maven.settings.io.jdom.SettingsJDOMWriter;
|
||||||
import org.apache.maven.settings.io.xpp3.SettingsXpp3Reader;
|
import org.apache.maven.settings.io.xpp3.SettingsXpp3Reader;
|
||||||
import org.apache.maven.settings.validation.DefaultSettingsValidator;
|
import org.apache.maven.settings.validation.DefaultSettingsValidator;
|
||||||
|
@ -78,7 +77,6 @@ import org.codehaus.plexus.component.repository.exception.ComponentRepositoryExc
|
||||||
import org.codehaus.plexus.configuration.PlexusConfigurationException;
|
import org.codehaus.plexus.configuration.PlexusConfigurationException;
|
||||||
import org.codehaus.plexus.logging.LoggerManager;
|
import org.codehaus.plexus.logging.LoggerManager;
|
||||||
import org.codehaus.plexus.util.IOUtil;
|
import org.codehaus.plexus.util.IOUtil;
|
||||||
import org.codehaus.plexus.util.StringUtils;
|
|
||||||
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
|
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
|
||||||
import org.jdom.Document;
|
import org.jdom.Document;
|
||||||
import org.jdom.Element;
|
import org.jdom.Element;
|
||||||
|
@ -406,7 +404,7 @@ public class MavenEmbedder
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
request = populator.populateDefaults( request, this );
|
request = populator.populateDefaults( request, configuration );
|
||||||
|
|
||||||
// This is necessary to make the MavenEmbedderProjectWithExtensionReadingTest work which uses
|
// This is necessary to make the MavenEmbedderProjectWithExtensionReadingTest work which uses
|
||||||
// a custom type for a dependency like this:
|
// a custom type for a dependency like this:
|
||||||
|
@ -654,7 +652,7 @@ public class MavenEmbedder
|
||||||
// simply cascade values in from requests used for individual executions.
|
// simply cascade values in from requests used for individual executions.
|
||||||
request = new DefaultMavenExecutionRequest();
|
request = new DefaultMavenExecutionRequest();
|
||||||
|
|
||||||
populator.populateDefaults( request, this );
|
populator.populateDefaults( request, configuration );
|
||||||
}
|
}
|
||||||
catch ( ComponentLookupException e )
|
catch ( ComponentLookupException e )
|
||||||
{
|
{
|
||||||
|
@ -785,98 +783,6 @@ public class MavenEmbedder
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
// Local Repository
|
|
||||||
// ----------------------------------------------------------------------
|
|
||||||
|
|
||||||
public ArtifactRepository createLocalRepository( Settings settings )
|
|
||||||
throws MavenEmbedderException
|
|
||||||
{
|
|
||||||
String localRepositoryPath = null;
|
|
||||||
|
|
||||||
if ( configuration.getLocalRepository() != null )
|
|
||||||
{
|
|
||||||
localRepositoryPath = configuration.getLocalRepository().getAbsolutePath();
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( StringUtils.isEmpty( localRepositoryPath ) )
|
|
||||||
{
|
|
||||||
localRepositoryPath = settings.getLocalRepository();
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( StringUtils.isEmpty( localRepositoryPath ) )
|
|
||||||
{
|
|
||||||
localRepositoryPath = MavenEmbedder.defaultUserLocalRepository.getAbsolutePath();
|
|
||||||
}
|
|
||||||
|
|
||||||
return createLocalRepository( localRepositoryPath, MavenEmbedder.DEFAULT_LOCAL_REPO_ID );
|
|
||||||
}
|
|
||||||
|
|
||||||
public ArtifactRepository createLocalRepository( String url,
|
|
||||||
String repositoryId )
|
|
||||||
throws MavenEmbedderException
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
return createRepository( canonicalFileUrl( url ), repositoryId );
|
|
||||||
}
|
|
||||||
catch ( IOException e )
|
|
||||||
{
|
|
||||||
throw new MavenEmbedderException( "Unable to resolve canonical path for local repository " + url, e );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private String canonicalFileUrl( String url )
|
|
||||||
throws IOException
|
|
||||||
{
|
|
||||||
if ( !url.startsWith( "file:" ) )
|
|
||||||
{
|
|
||||||
url = "file://" + url;
|
|
||||||
}
|
|
||||||
else if ( url.startsWith( "file:" ) && !url.startsWith( "file://" ) )
|
|
||||||
{
|
|
||||||
url = "file://" + url.substring( "file:".length() );
|
|
||||||
}
|
|
||||||
|
|
||||||
// So now we have an url of the form file://<path>
|
|
||||||
|
|
||||||
// We want to eliminate any relative path nonsense and lock down the path so we
|
|
||||||
// need to fully resolve it before any sub-modules use the path. This can happen
|
|
||||||
// when you are using a custom settings.xml that contains a relative path entry
|
|
||||||
// for the local repository setting.
|
|
||||||
|
|
||||||
File localRepository = new File( url.substring( "file://".length() ) );
|
|
||||||
|
|
||||||
if ( !localRepository.isAbsolute() )
|
|
||||||
{
|
|
||||||
url = "file://" + localRepository.getCanonicalPath();
|
|
||||||
}
|
|
||||||
|
|
||||||
return url;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ArtifactRepository createRepository( String url,
|
|
||||||
String repositoryId )
|
|
||||||
{
|
|
||||||
// snapshots vs releases
|
|
||||||
// offline = to turning the update policy off
|
|
||||||
|
|
||||||
//TODO: we'll need to allow finer grained creation of repositories but this will do for now
|
|
||||||
|
|
||||||
String updatePolicyFlag = ArtifactRepositoryPolicy.UPDATE_POLICY_ALWAYS;
|
|
||||||
|
|
||||||
String checksumPolicyFlag = ArtifactRepositoryPolicy.CHECKSUM_POLICY_WARN;
|
|
||||||
|
|
||||||
ArtifactRepositoryPolicy snapshotsPolicy =
|
|
||||||
new ArtifactRepositoryPolicy( true, updatePolicyFlag, checksumPolicyFlag );
|
|
||||||
|
|
||||||
ArtifactRepositoryPolicy releasesPolicy =
|
|
||||||
new ArtifactRepositoryPolicy( true, updatePolicyFlag, checksumPolicyFlag );
|
|
||||||
|
|
||||||
return artifactRepositoryFactory.createArtifactRepository( repositoryId, url, defaultArtifactRepositoryLayout,
|
|
||||||
snapshotsPolicy, releasesPolicy );
|
|
||||||
}
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// Configuration
|
// Configuration
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@ -902,7 +808,7 @@ public class MavenEmbedder
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
request = populator.populateDefaults( request, this );
|
request = populator.populateDefaults( request, configuration );
|
||||||
}
|
}
|
||||||
catch ( MavenEmbedderException e )
|
catch ( MavenEmbedderException e )
|
||||||
{
|
{
|
||||||
|
|
|
@ -20,11 +20,12 @@ package org.apache.maven.embedder.execution;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.maven.Maven;
|
import org.apache.maven.Maven;
|
||||||
import org.apache.maven.settings.SettingsConfigurationException;
|
|
||||||
import org.apache.maven.artifact.manager.WagonManager;
|
import org.apache.maven.artifact.manager.WagonManager;
|
||||||
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy;
|
import org.apache.maven.artifact.repository.ArtifactRepositoryPolicy;
|
||||||
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
||||||
|
import org.apache.maven.embedder.Configuration;
|
||||||
import org.apache.maven.embedder.MavenEmbedder;
|
import org.apache.maven.embedder.MavenEmbedder;
|
||||||
import org.apache.maven.embedder.MavenEmbedderException;
|
import org.apache.maven.embedder.MavenEmbedderException;
|
||||||
import org.apache.maven.execution.MavenExecutionRequest;
|
import org.apache.maven.execution.MavenExecutionRequest;
|
||||||
|
@ -38,6 +39,7 @@ import org.apache.maven.settings.Mirror;
|
||||||
import org.apache.maven.settings.Proxy;
|
import org.apache.maven.settings.Proxy;
|
||||||
import org.apache.maven.settings.Server;
|
import org.apache.maven.settings.Server;
|
||||||
import org.apache.maven.settings.Settings;
|
import org.apache.maven.settings.Settings;
|
||||||
|
import org.apache.maven.settings.SettingsConfigurationException;
|
||||||
import org.apache.maven.settings.SettingsUtils;
|
import org.apache.maven.settings.SettingsUtils;
|
||||||
import org.apache.maven.wagon.repository.RepositoryPermissions;
|
import org.apache.maven.wagon.repository.RepositoryPermissions;
|
||||||
import org.codehaus.plexus.PlexusConstants;
|
import org.codehaus.plexus.PlexusConstants;
|
||||||
|
@ -49,9 +51,11 @@ import org.codehaus.plexus.context.ContextException;
|
||||||
import org.codehaus.plexus.logging.AbstractLogEnabled;
|
import org.codehaus.plexus.logging.AbstractLogEnabled;
|
||||||
import org.codehaus.plexus.logging.Logger;
|
import org.codehaus.plexus.logging.Logger;
|
||||||
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
|
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
|
||||||
|
import org.codehaus.plexus.util.StringUtils;
|
||||||
import org.codehaus.plexus.util.xml.Xpp3Dom;
|
import org.codehaus.plexus.util.xml.Xpp3Dom;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -62,7 +66,8 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public class DefaultMavenExecutionRequestPopulator
|
public class DefaultMavenExecutionRequestPopulator
|
||||||
extends AbstractLogEnabled
|
extends AbstractLogEnabled
|
||||||
implements MavenExecutionRequestPopulator, Contextualizable
|
implements MavenExecutionRequestPopulator,
|
||||||
|
Contextualizable
|
||||||
{
|
{
|
||||||
private ArtifactRepositoryFactory artifactRepositoryFactory;
|
private ArtifactRepositoryFactory artifactRepositoryFactory;
|
||||||
|
|
||||||
|
@ -75,33 +80,41 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
private MavenSettingsBuilder settingsBuilder;
|
private MavenSettingsBuilder settingsBuilder;
|
||||||
|
|
||||||
public MavenExecutionRequest populateDefaults( MavenExecutionRequest request,
|
public MavenExecutionRequest populateDefaults( MavenExecutionRequest request,
|
||||||
MavenEmbedder embedder )
|
Configuration configuration )
|
||||||
throws MavenEmbedderException
|
throws MavenEmbedderException
|
||||||
{
|
{
|
||||||
// Actual POM File
|
// Actual POM File
|
||||||
|
|
||||||
if ( request.getPomFile() == null && request.getBaseDirectory() != null )
|
if ( request.getPomFile() == null && request.getBaseDirectory() != null )
|
||||||
{
|
{
|
||||||
File pom = new File( request.getBaseDirectory(), Maven.RELEASE_POMv4 );
|
File pom = new File(
|
||||||
|
request.getBaseDirectory(),
|
||||||
|
Maven.RELEASE_POMv4 );
|
||||||
|
|
||||||
if ( !pom.exists() )
|
if ( !pom.exists() )
|
||||||
{
|
{
|
||||||
pom = new File( request.getBaseDirectory(), Maven.POMv4 );
|
pom = new File(
|
||||||
|
request.getBaseDirectory(),
|
||||||
|
Maven.POMv4 );
|
||||||
}
|
}
|
||||||
|
|
||||||
request.setPomFile( pom.getAbsolutePath() );
|
request.setPomFile( pom.getAbsolutePath() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
request.setGlobalSettingsFile( configuration.getGlobalSettingsFile() );
|
||||||
|
|
||||||
|
request.setUserSettingsFile( configuration.getUserSettingsFile() );
|
||||||
|
|
||||||
if ( request.getSettings() == null )
|
if ( request.getSettings() == null )
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
request.setSettings(
|
request.setSettings(
|
||||||
settingsBuilder.buildSettings(
|
settingsBuilder.buildSettings(
|
||||||
embedder.getConfiguration().getUserSettingsFile(),
|
configuration.getUserSettingsFile(),
|
||||||
embedder.getConfiguration().getGlobalSettingsFile() ) );
|
configuration.getGlobalSettingsFile() ) );
|
||||||
}
|
}
|
||||||
catch( Exception e )
|
catch ( Exception e )
|
||||||
{
|
{
|
||||||
request.setSettings( new Settings() );
|
request.setSettings( new Settings() );
|
||||||
}
|
}
|
||||||
|
@ -109,7 +122,7 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
|
|
||||||
if ( request.getLocalRepository() == null )
|
if ( request.getLocalRepository() == null )
|
||||||
{
|
{
|
||||||
request.setLocalRepository( embedder.createLocalRepository( request.getSettings() ) );
|
request.setLocalRepository( createLocalRepository( request.getSettings(), configuration ) );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Repository update policies
|
// Repository update policies
|
||||||
|
@ -161,7 +174,9 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
}
|
}
|
||||||
catch ( Exception e )
|
catch ( Exception e )
|
||||||
{
|
{
|
||||||
throw new MavenEmbedderException( "Unable to configure Maven for execution", e );
|
throw new MavenEmbedderException(
|
||||||
|
"Unable to configure Maven for execution",
|
||||||
|
e );
|
||||||
}
|
}
|
||||||
|
|
||||||
// BaseDirectory in MavenExecutionRequest
|
// BaseDirectory in MavenExecutionRequest
|
||||||
|
@ -186,7 +201,9 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
|
|
||||||
ProfileManager globalProfileManager = new DefaultProfileManager( container );
|
ProfileManager globalProfileManager = new DefaultProfileManager( container );
|
||||||
|
|
||||||
loadSettingsProfiles( globalProfileManager, request.getSettings() );
|
loadSettingsProfiles(
|
||||||
|
globalProfileManager,
|
||||||
|
request.getSettings() );
|
||||||
|
|
||||||
globalProfileManager.explicitlyActivate( request.getActiveProfiles() );
|
globalProfileManager.explicitlyActivate( request.getActiveProfiles() );
|
||||||
|
|
||||||
|
@ -213,27 +230,41 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
throw new SettingsConfigurationException( "Proxy in settings.xml has no host" );
|
throw new SettingsConfigurationException( "Proxy in settings.xml has no host" );
|
||||||
}
|
}
|
||||||
|
|
||||||
wagonManager.addProxy( proxy.getProtocol(), proxy.getHost(), proxy.getPort(), proxy.getUsername(),
|
wagonManager.addProxy(
|
||||||
proxy.getPassword(), proxy.getNonProxyHosts() );
|
proxy.getProtocol(),
|
||||||
|
proxy.getHost(),
|
||||||
|
proxy.getPort(),
|
||||||
|
proxy.getUsername(),
|
||||||
|
proxy.getPassword(),
|
||||||
|
proxy.getNonProxyHosts() );
|
||||||
}
|
}
|
||||||
|
|
||||||
for ( Iterator i = settings.getServers().iterator(); i.hasNext(); )
|
for ( Iterator i = settings.getServers().iterator(); i.hasNext(); )
|
||||||
{
|
{
|
||||||
Server server = (Server) i.next();
|
Server server = (Server) i.next();
|
||||||
|
|
||||||
wagonManager.addAuthenticationInfo( server.getId(), server.getUsername(), server.getPassword(),
|
wagonManager.addAuthenticationInfo(
|
||||||
server.getPrivateKey(), server.getPassphrase() );
|
server.getId(),
|
||||||
|
server.getUsername(),
|
||||||
|
server.getPassword(),
|
||||||
|
server.getPrivateKey(),
|
||||||
|
server.getPassphrase() );
|
||||||
|
|
||||||
wagonManager.addPermissionInfo( server.getId(), server.getFilePermissions(), server.getDirectoryPermissions() );
|
wagonManager.addPermissionInfo(
|
||||||
|
server.getId(),
|
||||||
|
server.getFilePermissions(),
|
||||||
|
server.getDirectoryPermissions() );
|
||||||
|
|
||||||
if ( server.getConfiguration() != null )
|
if ( server.getConfiguration() != null )
|
||||||
{
|
{
|
||||||
wagonManager.addConfiguration( server.getId(), (Xpp3Dom) server.getConfiguration() );
|
wagonManager.addConfiguration(
|
||||||
|
server.getId(),
|
||||||
|
(Xpp3Dom) server.getConfiguration() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
RepositoryPermissions defaultPermissions = new RepositoryPermissions();
|
RepositoryPermissions defaultPermissions = new RepositoryPermissions();
|
||||||
|
|
||||||
defaultPermissions.setDirectoryMode( "775" );
|
defaultPermissions.setDirectoryMode( "775" );
|
||||||
|
|
||||||
defaultPermissions.setFileMode( "664" );
|
defaultPermissions.setFileMode( "664" );
|
||||||
|
@ -244,7 +275,10 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
{
|
{
|
||||||
Mirror mirror = (Mirror) i.next();
|
Mirror mirror = (Mirror) i.next();
|
||||||
|
|
||||||
wagonManager.addMirror( mirror.getId(), mirror.getMirrorOf(), mirror.getUrl() );
|
wagonManager.addMirror(
|
||||||
|
mirror.getId(),
|
||||||
|
mirror.getMirrorOf(),
|
||||||
|
mirror.getUrl() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
|
@ -263,7 +297,8 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
container = (PlexusContainer) context.get( PlexusConstants.PLEXUS_KEY );
|
container = (PlexusContainer) context.get( PlexusConstants.PLEXUS_KEY );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void loadSettingsProfiles( ProfileManager profileManager, Settings settings )
|
public void loadSettingsProfiles( ProfileManager profileManager,
|
||||||
|
Settings settings )
|
||||||
{
|
{
|
||||||
List settingsProfiles = settings.getProfiles();
|
List settingsProfiles = settings.getProfiles();
|
||||||
|
|
||||||
|
@ -284,4 +319,111 @@ public class DefaultMavenExecutionRequestPopulator
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
// Local Repository
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
public ArtifactRepository createLocalRepository( Settings settings, Configuration configuration )
|
||||||
|
throws MavenEmbedderException
|
||||||
|
{
|
||||||
|
String localRepositoryPath = null;
|
||||||
|
|
||||||
|
if ( configuration.getLocalRepository() != null )
|
||||||
|
{
|
||||||
|
localRepositoryPath = configuration.getLocalRepository().getAbsolutePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( StringUtils.isEmpty( localRepositoryPath ) )
|
||||||
|
{
|
||||||
|
localRepositoryPath = settings.getLocalRepository();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( StringUtils.isEmpty( localRepositoryPath ) )
|
||||||
|
{
|
||||||
|
localRepositoryPath = MavenEmbedder.defaultUserLocalRepository.getAbsolutePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
return createLocalRepository(
|
||||||
|
localRepositoryPath,
|
||||||
|
MavenEmbedder.DEFAULT_LOCAL_REPO_ID );
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArtifactRepository createLocalRepository( String url,
|
||||||
|
String repositoryId )
|
||||||
|
throws MavenEmbedderException
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
return createRepository(
|
||||||
|
canonicalFileUrl( url ),
|
||||||
|
repositoryId );
|
||||||
|
}
|
||||||
|
catch ( IOException e )
|
||||||
|
{
|
||||||
|
throw new MavenEmbedderException(
|
||||||
|
"Unable to resolve canonical path for local repository " + url,
|
||||||
|
e );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private String canonicalFileUrl( String url )
|
||||||
|
throws IOException
|
||||||
|
{
|
||||||
|
if ( !url.startsWith( "file:" ) )
|
||||||
|
{
|
||||||
|
url = "file://" + url;
|
||||||
|
}
|
||||||
|
else if ( url.startsWith( "file:" ) && !url.startsWith( "file://" ) )
|
||||||
|
{
|
||||||
|
url = "file://" + url.substring( "file:".length() );
|
||||||
|
}
|
||||||
|
|
||||||
|
// So now we have an url of the form file://<path>
|
||||||
|
|
||||||
|
// We want to eliminate any relative path nonsense and lock down the path so we
|
||||||
|
// need to fully resolve it before any sub-modules use the path. This can happen
|
||||||
|
// when you are using a custom settings.xml that contains a relative path entry
|
||||||
|
// for the local repository setting.
|
||||||
|
|
||||||
|
File localRepository = new File( url.substring( "file://".length() ) );
|
||||||
|
|
||||||
|
if ( !localRepository.isAbsolute() )
|
||||||
|
{
|
||||||
|
url = "file://" + localRepository.getCanonicalPath();
|
||||||
|
}
|
||||||
|
|
||||||
|
return url;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ArtifactRepository createRepository( String url,
|
||||||
|
String repositoryId )
|
||||||
|
{
|
||||||
|
// snapshots vs releases
|
||||||
|
// offline = to turning the update policy off
|
||||||
|
|
||||||
|
//TODO: we'll need to allow finer grained creation of repositories but this will do for now
|
||||||
|
|
||||||
|
String updatePolicyFlag = ArtifactRepositoryPolicy.UPDATE_POLICY_ALWAYS;
|
||||||
|
|
||||||
|
String checksumPolicyFlag = ArtifactRepositoryPolicy.CHECKSUM_POLICY_WARN;
|
||||||
|
|
||||||
|
ArtifactRepositoryPolicy snapshotsPolicy =
|
||||||
|
new ArtifactRepositoryPolicy(
|
||||||
|
true,
|
||||||
|
updatePolicyFlag,
|
||||||
|
checksumPolicyFlag );
|
||||||
|
|
||||||
|
ArtifactRepositoryPolicy releasesPolicy =
|
||||||
|
new ArtifactRepositoryPolicy(
|
||||||
|
true,
|
||||||
|
updatePolicyFlag,
|
||||||
|
checksumPolicyFlag );
|
||||||
|
|
||||||
|
return artifactRepositoryFactory.createArtifactRepository(
|
||||||
|
repositoryId,
|
||||||
|
url,
|
||||||
|
defaultArtifactRepositoryLayout,
|
||||||
|
snapshotsPolicy,
|
||||||
|
releasesPolicy );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,7 @@ package org.apache.maven.embedder.execution;
|
||||||
* under the License.
|
* under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.maven.embedder.MavenEmbedder;
|
import org.apache.maven.embedder.Configuration;
|
||||||
import org.apache.maven.embedder.MavenEmbedderException;
|
import org.apache.maven.embedder.MavenEmbedderException;
|
||||||
import org.apache.maven.execution.MavenExecutionRequest;
|
import org.apache.maven.execution.MavenExecutionRequest;
|
||||||
|
|
||||||
|
@ -27,6 +27,6 @@ public interface MavenExecutionRequestPopulator
|
||||||
{
|
{
|
||||||
String ROLE = MavenExecutionRequestPopulator.class.getName();
|
String ROLE = MavenExecutionRequestPopulator.class.getName();
|
||||||
|
|
||||||
MavenExecutionRequest populateDefaults( MavenExecutionRequest request, MavenEmbedder embedder )
|
MavenExecutionRequest populateDefaults( MavenExecutionRequest request, Configuration configuration )
|
||||||
throws MavenEmbedderException;
|
throws MavenEmbedderException;
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,11 +27,15 @@ under the License.
|
||||||
<role>org.apache.maven.artifact.manager.WagonManager</role>
|
<role>org.apache.maven.artifact.manager.WagonManager</role>
|
||||||
<role-hint>default</role-hint>
|
<role-hint>default</role-hint>
|
||||||
</requirement>
|
</requirement>
|
||||||
|
<requirement>
|
||||||
|
<role>org.apache.maven.settings.MavenSettingsBuilder</role>
|
||||||
|
</requirement>
|
||||||
<requirement>
|
<requirement>
|
||||||
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role>
|
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role>
|
||||||
</requirement>
|
</requirement>
|
||||||
<requirement>
|
<requirement>
|
||||||
<role>org.apache.maven.settings.MavenSettingsBuilder</role>
|
<role>org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout</role>
|
||||||
|
<role-hint>default</role-hint>
|
||||||
</requirement>
|
</requirement>
|
||||||
</requirements>
|
</requirements>
|
||||||
</component>
|
</component>
|
||||||
|
|
|
@ -59,7 +59,7 @@ public class MavenEmbedderExampleTest
|
||||||
|
|
||||||
if ( result.hasExceptions() )
|
if ( result.hasExceptions() )
|
||||||
{
|
{
|
||||||
// Notify user that exceptions have occured.
|
fail( ((Exception)result.getExceptions().get( 0 )).getMessage() );
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
Loading…
Reference in New Issue