[MASSEMBLY-210] Including the ancestry of the current project in the repository.
git-svn-id: https://svn.apache.org/repos/asf/maven/shared/trunk@543255 13f79535-47bb-0310-9956-ffa450edef68
diff --git a/src/main/java/org/apache/maven/shared/repository/DefaultRepositoryAssembler.java b/src/main/java/org/apache/maven/shared/repository/DefaultRepositoryAssembler.java
index d533e43..ead08bf 100755
--- a/src/main/java/org/apache/maven/shared/repository/DefaultRepositoryAssembler.java
+++ b/src/main/java/org/apache/maven/shared/repository/DefaultRepositoryAssembler.java
@@ -183,6 +183,9 @@
{
assembleRepositoryMetadata( result, filter, centralRepository, targetRepository );
}
+
+ addPomWithAncestry( project.getArtifact(), project.getRemoteArtifactRepositories(), localRepository,
+ targetRepository, groupVersionAlignments );
}
private ArtifactFilter buildRepositoryFilter( RepositoryInfo repository, MavenProject project )
@@ -276,38 +279,7 @@
writeChecksums( targetFile );
- if ( !"pom".equals( a.getType() ) )
- {
- a = artifactFactory.createProjectArtifact( a.getGroupId(), a.getArtifactId(), a.getVersion() );
-
- MavenProject p = projectBuilder.buildFromRepository( a,
- project.getRemoteArtifactRepositories(),
- localRepository );
-
- do
- {
- a = artifactFactory.createProjectArtifact( p.getGroupId(), p.getArtifactId(), p
- .getVersion() );
-
- setAlignment( a, groupVersionAlignments );
-
- File sourceFile = new File( localRepository.getBasedir(), localRepository.pathOf( a ) );
-
- if ( !sourceFile.exists() )
- {
- break;
- }
-
- targetFile = new File( targetRepository.getBasedir(), targetRepository.pathOf( a ) );
-
- FileUtils.copyFile( sourceFile, targetFile );
-
- writeChecksums( targetFile );
-
- p = p.getParent();
- }
- while ( p != null );
- }
+ addPomWithAncestry( a, project.getRemoteArtifactRepositories(), localRepository, targetRepository, groupVersionAlignments );
}
}
}
@@ -323,9 +295,66 @@
{
throw new RepositoryAssemblyException( "Error writing artifact metdata.", e );
}
- catch ( ProjectBuildingException e )
+ }
+
+ private void addPomWithAncestry( Artifact artifact, List remoteArtifactRepositories,
+ ArtifactRepository localRepository, ArtifactRepository targetRepository,
+ Map groupVersionAlignments )
+ throws RepositoryAssemblyException
+ {
+ if ( !"pom".equals( artifact.getType() ) )
{
- throw new RepositoryAssemblyException( "Error reading POM.", e );
+ artifact = artifactFactory.createProjectArtifact( artifact.getGroupId(), artifact.getArtifactId(), artifact.getVersion() );
+
+ MavenProject p;
+ try
+ {
+ p = projectBuilder.buildFromRepository( artifact,
+ remoteArtifactRepositories,
+ localRepository );
+ }
+ catch ( ProjectBuildingException e )
+ {
+ throw new RepositoryAssemblyException( "Error reading POM: " + artifact.getId(), e );
+ }
+
+ do
+ {
+ artifact = artifactFactory.createProjectArtifact( p.getGroupId(), p.getArtifactId(), p
+ .getVersion() );
+
+ setAlignment( artifact, groupVersionAlignments );
+
+ File sourceFile = new File( localRepository.getBasedir(), localRepository.pathOf( artifact ) );
+
+ if ( !sourceFile.exists() )
+ {
+ break;
+ }
+
+ File targetFile = new File( targetRepository.getBasedir(), targetRepository.pathOf( artifact ) );
+
+ try
+ {
+ FileUtils.copyFile( sourceFile, targetFile );
+ }
+ catch ( IOException e )
+ {
+ throw new RepositoryAssemblyException( "Error writing POM metdata: " + artifact.getId(), e );
+ }
+
+ try
+ {
+ writeChecksums( targetFile );
+ }
+ catch ( IOException e )
+ {
+ throw new RepositoryAssemblyException( "Error writing checksums for POM: " + artifact.getId(), e );
+ }
+
+ p = p.getParent();
+ }
+ while ( p != null );
}
}