diff options
Diffstat (limited to 'framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings')
4 files changed, 623 insertions, 0 deletions
diff --git a/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/DefaultMavenSettingsBuilder.java b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/DefaultMavenSettingsBuilder.java new file mode 100644 index 00000000..820d886e --- /dev/null +++ b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/DefaultMavenSettingsBuilder.java @@ -0,0 +1,158 @@ +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.io.File; +import java.io.IOException; + +import org.apache.maven.execution.MavenExecutionRequest; +import org.apache.maven.properties.internal.SystemProperties; +import org.apache.maven.settings.building.DefaultSettingsBuildingRequest; +import org.apache.maven.settings.building.SettingsBuilder; +import org.apache.maven.settings.building.SettingsBuildingException; +import org.apache.maven.settings.building.SettingsBuildingRequest; +import org.codehaus.plexus.component.annotations.Component; +import org.codehaus.plexus.component.annotations.Requirement; +import org.codehaus.plexus.logging.AbstractLogEnabled; +import org.codehaus.plexus.util.StringUtils; +import org.codehaus.plexus.util.xml.pull.XmlPullParserException; + +/** + * @author jdcasey + */ +@Component( role = MavenSettingsBuilder.class ) +public class DefaultMavenSettingsBuilder + extends AbstractLogEnabled + implements MavenSettingsBuilder +{ + + @Requirement + private SettingsBuilder settingsBuilder; + + public Settings buildSettings() + throws IOException, XmlPullParserException + { + File userSettingsFile = + getFile( "${user.home}/.m2/settings.xml", "user.home", + MavenSettingsBuilder.ALT_USER_SETTINGS_XML_LOCATION ); + + return buildSettings( userSettingsFile ); + } + + public Settings buildSettings( boolean useCachedSettings ) + throws IOException, XmlPullParserException + { + return buildSettings(); + } + + public Settings buildSettings( File userSettingsFile ) + throws IOException, XmlPullParserException + { + File globalSettingsFile = + getFile( "${maven.home}/conf/settings.xml", "maven.home", + MavenSettingsBuilder.ALT_GLOBAL_SETTINGS_XML_LOCATION ); + + SettingsBuildingRequest request = new DefaultSettingsBuildingRequest(); + request.setUserSettingsFile( userSettingsFile ); + request.setGlobalSettingsFile( globalSettingsFile ); + request.setSystemProperties( SystemProperties.getSystemProperties() ); + return build( request ); + } + + public Settings buildSettings( File userSettingsFile, boolean useCachedSettings ) + throws IOException, XmlPullParserException + { + return buildSettings( userSettingsFile ); + } + + private Settings build( SettingsBuildingRequest request ) + throws IOException, XmlPullParserException + { + try + { + return settingsBuilder.build( request ).getEffectiveSettings(); + } + catch ( SettingsBuildingException e ) + { + throw (IOException) new IOException( e.getMessage() ).initCause( e ); + } + } + + /** @since 2.1 */ + public Settings buildSettings( MavenExecutionRequest request ) + throws IOException, XmlPullParserException + { + SettingsBuildingRequest settingsRequest = new DefaultSettingsBuildingRequest(); + settingsRequest.setUserSettingsFile( request.getUserSettingsFile() ); + settingsRequest.setGlobalSettingsFile( request.getGlobalSettingsFile() ); + settingsRequest.setUserProperties( request.getUserProperties() ); + settingsRequest.setSystemProperties( request.getSystemProperties() ); + + return build( settingsRequest ); + } + + private File getFile( String pathPattern, String basedirSysProp, String altLocationSysProp ) + { + // ------------------------------------------------------------------------------------- + // Alright, here's the justification for all the regexp wizardry below... + // + // Continuum and other server-like apps may need to locate the user-level and + // global-level settings somewhere other than ${user.home} and ${maven.home}, + // respectively. Using a simple replacement of these patterns will allow them + // to specify the absolute path to these files in a customized components.xml + // file. Ideally, we'd do full pattern-evaluation against the sysprops, but this + // is a first step. There are several replacements below, in order to normalize + // the path character before we operate on the string as a regex input, and + // in order to avoid surprises with the File construction... + // ------------------------------------------------------------------------------------- + + String path = System.getProperty( altLocationSysProp ); + + if ( StringUtils.isEmpty( path ) ) + { + // TODO: This replacing shouldn't be necessary as user.home should be in the + // context of the container and thus the value would be interpolated by Plexus + String basedir = System.getProperty( basedirSysProp ); + if ( basedir == null ) + { + basedir = System.getProperty( "user.dir" ); + } + + basedir = basedir.replaceAll( "\\\\", "/" ); + basedir = basedir.replaceAll( "\\$", "\\\\\\$" ); + + path = pathPattern.replaceAll( "\\$\\{" + basedirSysProp + "\\}", basedir ); + path = path.replaceAll( "\\\\", "/" ); + // --------------------------------------------------------------------------------- + // I'm not sure if this last regexp was really intended to disallow the usage of + // network paths as user.home directory. Unfortunately it did. I removed it and + // have not detected any problems yet. + // --------------------------------------------------------------------------------- + // path = path.replaceAll( "//", "/" ); + + return new File( path ).getAbsoluteFile(); + } + else + { + return new File( path ).getAbsoluteFile(); + } + } + +} diff --git a/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/MavenSettingsBuilder.java b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/MavenSettingsBuilder.java new file mode 100644 index 00000000..c79a843d --- /dev/null +++ b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/MavenSettingsBuilder.java @@ -0,0 +1,81 @@ +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.io.File; +import java.io.IOException; + +import org.apache.maven.execution.MavenExecutionRequest; +import org.codehaus.plexus.util.xml.pull.XmlPullParserException; + +/** + * @author jdcasey + * @author Jason van Zyl + */ +@Deprecated +public interface MavenSettingsBuilder +{ + + String ROLE = MavenSettingsBuilder.class.getName(); + + String ALT_USER_SETTINGS_XML_LOCATION = "org.apache.maven.user-settings"; + String ALT_GLOBAL_SETTINGS_XML_LOCATION = "org.apache.maven.global-settings"; + String ALT_LOCAL_REPOSITORY_LOCATION = "maven.repo.local"; + + Settings buildSettings( MavenExecutionRequest request ) + throws IOException, XmlPullParserException; + + /** + * @return a <code>Settings</code> object from the user settings file. + * @throws IOException if any + * @throws XmlPullParserException if any + */ + Settings buildSettings() + throws IOException, XmlPullParserException; + + /** + * @param useCachedSettings if true, doesn't reload the user settings + * @return a <code>Settings</code> object from the user settings file. + * @throws IOException if any + * @throws XmlPullParserException if any + */ + Settings buildSettings( boolean useCachedSettings ) + throws IOException, XmlPullParserException; + + /** + * @param userSettingsFile a given user settings file + * @return a <code>Settings</code> object from the user settings file. + * @throws IOException if any + * @throws XmlPullParserException if any + */ + Settings buildSettings( File userSettingsFile ) + throws IOException, XmlPullParserException; + + /** + * @param userSettingsFile a given user settings file + * @param useCachedSettings if true, doesn't reload the user settings + * @return a <code>Settings</code> object from the user settings file. + * @throws IOException if any + * @throws XmlPullParserException if any + */ + Settings buildSettings( File userSettingsFile, boolean useCachedSettings ) + throws IOException, XmlPullParserException; + +} diff --git a/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/SettingsConfigurationException.java b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/SettingsConfigurationException.java new file mode 100644 index 00000000..6fab6501 --- /dev/null +++ b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/SettingsConfigurationException.java @@ -0,0 +1,63 @@ +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. + */ + +/** + * If there was an error in the settings file. + * + * @author <a href="mailto:brett@apache.org">Brett Porter</a> + */ +public class SettingsConfigurationException + extends Exception +{ + private int lineNumber; + + private int columnNumber; + + public SettingsConfigurationException( String message ) + { + super( message ); + } + + public SettingsConfigurationException( String message, Throwable cause ) + { + super( message, cause ); + } + + public SettingsConfigurationException( String message, Throwable cause, int lineNumber, int columnNumber ) + { + super( message + ( lineNumber > 0 ? "\n Line: " + lineNumber : "" ) + + ( columnNumber > 0 ? "\n Column: " + columnNumber : "" ), cause ); + this.lineNumber = lineNumber; + this.columnNumber = columnNumber; + } + + public int getColumnNumber() + { + return columnNumber; + } + + public int getLineNumber() + { + return lineNumber; + } + + +} diff --git a/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/SettingsUtils.java b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/SettingsUtils.java new file mode 100644 index 00000000..8da696e8 --- /dev/null +++ b/framework/src/maven/apache-maven-3.3.3/maven-core/src/main/java/org/apache/maven/settings/SettingsUtils.java @@ -0,0 +1,321 @@ +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 org.apache.maven.model.ActivationFile; +import org.apache.maven.settings.merge.MavenSettingsMerger; + +import java.util.List; + +/** + * Several convenience methods to handle settings + * + * @author <a href="mailto:vincent.siveton@gmail.com">Vincent Siveton</a> + */ +public final class SettingsUtils +{ + + private SettingsUtils() + { + // don't allow construction. + } + + /** + * @param dominant + * @param recessive + * @param recessiveSourceLevel + */ + public static void merge( Settings dominant, Settings recessive, String recessiveSourceLevel ) + { + new MavenSettingsMerger().merge( dominant, recessive, recessiveSourceLevel ); + } + + /** + * @param modelProfile + * @return a profile + */ + public static Profile convertToSettingsProfile( org.apache.maven.model.Profile modelProfile ) + { + Profile profile = new Profile(); + + profile.setId( modelProfile.getId() ); + + org.apache.maven.model.Activation modelActivation = modelProfile.getActivation(); + + if ( modelActivation != null ) + { + Activation activation = new Activation(); + + activation.setActiveByDefault( modelActivation.isActiveByDefault() ); + + activation.setJdk( modelActivation.getJdk() ); + + org.apache.maven.model.ActivationProperty modelProp = modelActivation.getProperty(); + + if ( modelProp != null ) + { + ActivationProperty prop = new ActivationProperty(); + prop.setName( modelProp.getName() ); + prop.setValue( modelProp.getValue() ); + activation.setProperty( prop ); + } + + org.apache.maven.model.ActivationOS modelOs = modelActivation.getOs(); + + if ( modelOs != null ) + { + ActivationOS os = new ActivationOS(); + + os.setArch( modelOs.getArch() ); + os.setFamily( modelOs.getFamily() ); + os.setName( modelOs.getName() ); + os.setVersion( modelOs.getVersion() ); + + activation.setOs( os ); + } + + ActivationFile modelFile = modelActivation.getFile(); + + if ( modelFile != null ) + { + org.apache.maven.settings.ActivationFile file = new org.apache.maven.settings.ActivationFile(); + + file.setExists( modelFile.getExists() ); + file.setMissing( modelFile.getMissing() ); + + activation.setFile( file ); + } + + profile.setActivation( activation ); + } + + profile.setProperties( modelProfile.getProperties() ); + + List<org.apache.maven.model.Repository> repos = modelProfile.getRepositories(); + if ( repos != null ) + { + for ( org.apache.maven.model.Repository repo : repos ) + { + profile.addRepository( convertToSettingsRepository( repo ) ); + } + } + + List<org.apache.maven.model.Repository> pluginRepos = modelProfile.getPluginRepositories(); + if ( pluginRepos != null ) + { + for ( org.apache.maven.model.Repository pluginRepo : pluginRepos ) + { + profile.addPluginRepository( convertToSettingsRepository( pluginRepo ) ); + } + } + + return profile; + } + + /** + * @param settingsProfile + * @return a profile + */ + public static org.apache.maven.model.Profile convertFromSettingsProfile( Profile settingsProfile ) + { + org.apache.maven.model.Profile profile = new org.apache.maven.model.Profile(); + + profile.setId( settingsProfile.getId() ); + + profile.setSource( "settings.xml" ); + + Activation settingsActivation = settingsProfile.getActivation(); + + if ( settingsActivation != null ) + { + org.apache.maven.model.Activation activation = new org.apache.maven.model.Activation(); + + activation.setActiveByDefault( settingsActivation.isActiveByDefault() ); + + activation.setJdk( settingsActivation.getJdk() ); + + ActivationProperty settingsProp = settingsActivation.getProperty(); + + if ( settingsProp != null ) + { + org.apache.maven.model.ActivationProperty prop = new org.apache.maven.model.ActivationProperty(); + + prop.setName( settingsProp.getName() ); + prop.setValue( settingsProp.getValue() ); + + activation.setProperty( prop ); + } + + ActivationOS settingsOs = settingsActivation.getOs(); + + if ( settingsOs != null ) + { + org.apache.maven.model.ActivationOS os = new org.apache.maven.model.ActivationOS(); + + os.setArch( settingsOs.getArch() ); + os.setFamily( settingsOs.getFamily() ); + os.setName( settingsOs.getName() ); + os.setVersion( settingsOs.getVersion() ); + + activation.setOs( os ); + } + + org.apache.maven.settings.ActivationFile settingsFile = settingsActivation.getFile(); + + if ( settingsFile != null ) + { + ActivationFile file = new ActivationFile(); + + file.setExists( settingsFile.getExists() ); + file.setMissing( settingsFile.getMissing() ); + + activation.setFile( file ); + } + + profile.setActivation( activation ); + } + + profile.setProperties( settingsProfile.getProperties() ); + + List<Repository> repos = settingsProfile.getRepositories(); + if ( repos != null ) + { + for ( Repository repo : repos ) + { + profile.addRepository( convertFromSettingsRepository( repo ) ); + } + } + + List<Repository> pluginRepos = settingsProfile.getPluginRepositories(); + if ( pluginRepos != null ) + { + for ( Repository pluginRepo : pluginRepos ) + { + profile.addPluginRepository( convertFromSettingsRepository( pluginRepo ) ); + } + } + + return profile; + } + + /** + * @param settingsRepo + * @return a repository + */ + private static org.apache.maven.model.Repository convertFromSettingsRepository( Repository settingsRepo ) + { + org.apache.maven.model.Repository repo = new org.apache.maven.model.Repository(); + + repo.setId( settingsRepo.getId() ); + repo.setLayout( settingsRepo.getLayout() ); + repo.setName( settingsRepo.getName() ); + repo.setUrl( settingsRepo.getUrl() ); + + if ( settingsRepo.getSnapshots() != null ) + { + repo.setSnapshots( convertRepositoryPolicy( settingsRepo.getSnapshots() ) ); + } + if ( settingsRepo.getReleases() != null ) + { + repo.setReleases( convertRepositoryPolicy( settingsRepo.getReleases() ) ); + } + + return repo; + } + + /** + * @param settingsPolicy + * @return a RepositoryPolicy + */ + private static org.apache.maven.model.RepositoryPolicy convertRepositoryPolicy( RepositoryPolicy settingsPolicy ) + { + org.apache.maven.model.RepositoryPolicy policy = new org.apache.maven.model.RepositoryPolicy(); + policy.setEnabled( settingsPolicy.isEnabled() ); + policy.setUpdatePolicy( settingsPolicy.getUpdatePolicy() ); + policy.setChecksumPolicy( settingsPolicy.getChecksumPolicy() ); + return policy; + } + + /** + * @param modelRepo + * @return a repository + */ + private static Repository convertToSettingsRepository( org.apache.maven.model.Repository modelRepo ) + { + Repository repo = new Repository(); + + repo.setId( modelRepo.getId() ); + repo.setLayout( modelRepo.getLayout() ); + repo.setName( modelRepo.getName() ); + repo.setUrl( modelRepo.getUrl() ); + + if ( modelRepo.getSnapshots() != null ) + { + repo.setSnapshots( convertRepositoryPolicy( modelRepo.getSnapshots() ) ); + } + if ( modelRepo.getReleases() != null ) + { + repo.setReleases( convertRepositoryPolicy( modelRepo.getReleases() ) ); + } + + return repo; + } + + /** + * @param modelPolicy + * @return a RepositoryPolicy + */ + private static RepositoryPolicy convertRepositoryPolicy( org.apache.maven.model.RepositoryPolicy modelPolicy ) + { + RepositoryPolicy policy = new RepositoryPolicy(); + policy.setEnabled( modelPolicy.isEnabled() ); + policy.setUpdatePolicy( modelPolicy.getUpdatePolicy() ); + policy.setChecksumPolicy( modelPolicy.getChecksumPolicy() ); + return policy; + } + + /** + * @param settings could be null + * @return a new instance of settings or null if settings was null. + */ + public static Settings copySettings( Settings settings ) + { + if ( settings == null ) + { + return null; + } + + Settings clone = new Settings(); + clone.setActiveProfiles( settings.getActiveProfiles() ); + clone.setInteractiveMode( settings.isInteractiveMode() ); + clone.setLocalRepository( settings.getLocalRepository() ); + clone.setMirrors( settings.getMirrors() ); + clone.setModelEncoding( settings.getModelEncoding() ); + clone.setOffline( settings.isOffline() ); + clone.setPluginGroups( settings.getPluginGroups() ); + clone.setProfiles( settings.getProfiles() ); + clone.setProxies( settings.getProxies() ); + clone.setServers( settings.getServers() ); + clone.setSourceLevel( settings.getSourceLevel() ); + clone.setUsePluginRegistry( settings.isUsePluginRegistry() ); + + return clone; + } +} |