o Fixed lazy repo creation to cache result repo

git-svn-id: https://svn.apache.org/repos/asf/maven/maven-3/trunk@1021505 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Benjamin Bentmann 2010-10-11 21:01:06 +00:00
parent 947973e857
commit f5ad9a458a
1 changed files with 40 additions and 24 deletions

View File

@ -1844,19 +1844,27 @@ public class MavenProject
protected ArtifactRepository getReleaseArtifactRepository() protected ArtifactRepository getReleaseArtifactRepository()
{ {
if ( getDistributionManagement() != null && getDistributionManagement().getRepository() != null ) if ( releaseArtifactRepository == null )
{ {
try if ( getDistributionManagement() != null && getDistributionManagement().getRepository() != null )
{
ArtifactRepository repo =
repositorySystem.buildArtifactRepository( getDistributionManagement().getRepository() );
repositorySystem.injectProxy( projectBuilderConfiguration.getRepositorySession(), Arrays.asList( repo ) );
repositorySystem.injectAuthentication( projectBuilderConfiguration.getRepositorySession(),
Arrays.asList( repo ) );
setReleaseArtifactRepository( repo );
}
catch ( InvalidRepositoryException e )
{ {
try
{
ArtifactRepository repo =
repositorySystem.buildArtifactRepository( getDistributionManagement().getRepository() );
repositorySystem.injectProxy( projectBuilderConfiguration.getRepositorySession(),
Arrays.asList( repo ) );
repositorySystem.injectAuthentication( projectBuilderConfiguration.getRepositorySession(),
Arrays.asList( repo ) );
setReleaseArtifactRepository( repo );
}
catch ( InvalidRepositoryException e )
{
if ( logger != null )
{
logger.debug( "Failed to create release distribution repository for " + getId(), e );
}
}
} }
} }
@ -1865,19 +1873,27 @@ public class MavenProject
protected ArtifactRepository getSnapshotArtifactRepository() protected ArtifactRepository getSnapshotArtifactRepository()
{ {
if ( getDistributionManagement() != null && getDistributionManagement().getSnapshotRepository() != null ) if ( snapshotArtifactRepository == null )
{ {
try if ( getDistributionManagement() != null && getDistributionManagement().getSnapshotRepository() != null )
{
ArtifactRepository repo =
repositorySystem.buildArtifactRepository( getDistributionManagement().getSnapshotRepository() );
repositorySystem.injectProxy( projectBuilderConfiguration.getRepositorySession(), Arrays.asList( repo ) );
repositorySystem.injectAuthentication( projectBuilderConfiguration.getRepositorySession(),
Arrays.asList( repo ) );
setSnapshotArtifactRepository( repo );
}
catch ( InvalidRepositoryException e )
{ {
try
{
ArtifactRepository repo =
repositorySystem.buildArtifactRepository( getDistributionManagement().getSnapshotRepository() );
repositorySystem.injectProxy( projectBuilderConfiguration.getRepositorySession(),
Arrays.asList( repo ) );
repositorySystem.injectAuthentication( projectBuilderConfiguration.getRepositorySession(),
Arrays.asList( repo ) );
setSnapshotArtifactRepository( repo );
}
catch ( InvalidRepositoryException e )
{
if ( logger != null )
{
logger.debug( "Failed to create snapshot distribution repository for " + getId(), e );
}
}
} }
} }