o Refactored RepositoryCleaner to use DiscoveryPhase and RewritePhase.

o Added the ability to read a pom and figure out whether it's a v4 pom (based on presence of modelVersion)
o Added a more accurate counter for artifacts that are actually rewritten successfully, rather than just the ones that enter the rewriting process.
o Probably need to add the phases still...


git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@169041 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
John Dennis Casey 2005-05-07 05:45:20 +00:00
parent ecc12bd005
commit 099c5383c2
49 changed files with 336 additions and 668 deletions

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Branch.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Build.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Contributor.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Dependency.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Developer.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class FileSet.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class License.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class MailingList.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Organization.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class PackageGroup.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Repository.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Resource.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class SourceModification.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class UnitTest.
*

View File

@ -8,7 +8,6 @@ package org.apache.maven.model.v3_0_0;
//- Imported classes and packages -/
//---------------------------------/
/**
* Class Version.
*

View File

@ -72,7 +72,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Branch parseBranch( String tagName, XmlPullParser parser ) throws Exception
private Branch parseBranch( String tagName, XmlPullParser parser )
throws Exception
{
Branch branch = new Branch();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -98,7 +99,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Build parseBuild( String tagName, XmlPullParser parser ) throws Exception
private Build parseBuild( String tagName, XmlPullParser parser )
throws Exception
{
Build build = new Build();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -176,7 +178,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Contributor parseContributor( String tagName, XmlPullParser parser ) throws Exception
private Contributor parseContributor( String tagName, XmlPullParser parser )
throws Exception
{
Contributor contributor = new Contributor();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -234,7 +237,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Dependency parseDependency( String tagName, XmlPullParser parser ) throws Exception
private Dependency parseDependency( String tagName, XmlPullParser parser )
throws Exception
{
Dependency dependency = new Dependency();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -293,7 +297,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Developer parseDeveloper( String tagName, XmlPullParser parser ) throws Exception
private Developer parseDeveloper( String tagName, XmlPullParser parser )
throws Exception
{
Developer developer = new Developer();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -355,7 +360,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private FileSet parseFileSet( String tagName, XmlPullParser parser ) throws Exception
private FileSet parseFileSet( String tagName, XmlPullParser parser )
throws Exception
{
FileSet fileSet = new FileSet();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -413,7 +419,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private License parseLicense( String tagName, XmlPullParser parser ) throws Exception
private License parseLicense( String tagName, XmlPullParser parser )
throws Exception
{
License license = new License();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -451,7 +458,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private MailingList parseMailingList( String tagName, XmlPullParser parser ) throws Exception
private MailingList parseMailingList( String tagName, XmlPullParser parser )
throws Exception
{
MailingList mailingList = new MailingList();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -489,7 +497,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Model parseModel( String tagName, XmlPullParser parser ) throws Exception
private Model parseModel( String tagName, XmlPullParser parser )
throws Exception
{
Model model = new Model();
int eventType = parser.getEventType();
@ -753,7 +762,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Organization parseOrganization( String tagName, XmlPullParser parser ) throws Exception
private Organization parseOrganization( String tagName, XmlPullParser parser )
throws Exception
{
Organization organization = new Organization();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -787,7 +797,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private PackageGroup parsePackageGroup( String tagName, XmlPullParser parser ) throws Exception
private PackageGroup parsePackageGroup( String tagName, XmlPullParser parser )
throws Exception
{
PackageGroup packageGroup = new PackageGroup();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -817,7 +828,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private PatternSet parsePatternSet( String tagName, XmlPullParser parser ) throws Exception
private PatternSet parsePatternSet( String tagName, XmlPullParser parser )
throws Exception
{
PatternSet patternSet = new PatternSet();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -871,7 +883,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Repository parseRepository( String tagName, XmlPullParser parser ) throws Exception
private Repository parseRepository( String tagName, XmlPullParser parser )
throws Exception
{
Repository repository = new Repository();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -905,7 +918,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Resource parseResource( String tagName, XmlPullParser parser ) throws Exception
private Resource parseResource( String tagName, XmlPullParser parser )
throws Exception
{
Resource resource = new Resource();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -971,7 +985,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private SourceModification parseSourceModification( String tagName, XmlPullParser parser ) throws Exception
private SourceModification parseSourceModification( String tagName, XmlPullParser parser )
throws Exception
{
SourceModification sourceModification = new SourceModification();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -1037,7 +1052,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private UnitTest parseUnitTest( String tagName, XmlPullParser parser ) throws Exception
private UnitTest parseUnitTest( String tagName, XmlPullParser parser )
throws Exception
{
UnitTest unitTest = new UnitTest();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -1107,7 +1123,8 @@ public class MavenXpp3Reader
* @param tagName
* @param parser
*/
private Version parseVersion( String tagName, XmlPullParser parser ) throws Exception
private Version parseVersion( String tagName, XmlPullParser parser )
throws Exception
{
Version version = new Version();
while ( parser.nextTag() == XmlPullParser.START_TAG )
@ -1140,7 +1157,8 @@ public class MavenXpp3Reader
*
* @param reader
*/
public Model read( Reader reader ) throws Exception
public Model read( Reader reader )
throws Exception
{
XmlPullParser parser = new MXParser();
parser.setInput( reader );

View File

@ -63,7 +63,8 @@ public class MavenXpp3Writer
* @param writer
* @param model
*/
public void write( Writer writer, Model model ) throws Exception
public void write( Writer writer, Model model )
throws Exception
{
serializer = new MXSerializer();
serializer.setProperty( "http://xmlpull.org/v1/doc/properties.html#serializer-indentation", " " );
@ -79,7 +80,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeBranch( Branch branch, String tagName, XmlSerializer serializer ) throws Exception
private void writeBranch( Branch branch, String tagName, XmlSerializer serializer )
throws Exception
{
if ( branch != null )
{
@ -99,7 +101,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeBuild( Build build, String tagName, XmlSerializer serializer ) throws Exception
private void writeBuild( Build build, String tagName, XmlSerializer serializer )
throws Exception
{
if ( build != null )
{
@ -165,7 +168,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeContributor( Contributor contributor, String tagName, XmlSerializer serializer ) throws Exception
private void writeContributor( Contributor contributor, String tagName, XmlSerializer serializer )
throws Exception
{
if ( contributor != null )
{
@ -213,7 +217,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeDependency( Dependency dependency, String tagName, XmlSerializer serializer ) throws Exception
private void writeDependency( Dependency dependency, String tagName, XmlSerializer serializer )
throws Exception
{
if ( dependency != null )
{
@ -271,7 +276,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeDeveloper( Developer developer, String tagName, XmlSerializer serializer ) throws Exception
private void writeDeveloper( Developer developer, String tagName, XmlSerializer serializer )
throws Exception
{
if ( developer != null )
{
@ -323,7 +329,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeFileSet( FileSet fileSet, String tagName, XmlSerializer serializer ) throws Exception
private void writeFileSet( FileSet fileSet, String tagName, XmlSerializer serializer )
throws Exception
{
if ( fileSet != null )
{
@ -364,7 +371,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeLicense( License license, String tagName, XmlSerializer serializer ) throws Exception
private void writeLicense( License license, String tagName, XmlSerializer serializer )
throws Exception
{
if ( license != null )
{
@ -398,7 +406,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeMailingList( MailingList mailingList, String tagName, XmlSerializer serializer ) throws Exception
private void writeMailingList( MailingList mailingList, String tagName, XmlSerializer serializer )
throws Exception
{
if ( mailingList != null )
{
@ -433,7 +442,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeModel( Model model, String tagName, XmlSerializer serializer ) throws Exception
private void writeModel( Model model, String tagName, XmlSerializer serializer )
throws Exception
{
if ( model != null )
{
@ -706,7 +716,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writePatternSet( PatternSet patternSet, String tagName, XmlSerializer serializer ) throws Exception
private void writePatternSet( PatternSet patternSet, String tagName, XmlSerializer serializer )
throws Exception
{
if ( patternSet != null )
{
@ -742,7 +753,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeRepository( Repository repository, String tagName, XmlSerializer serializer ) throws Exception
private void writeRepository( Repository repository, String tagName, XmlSerializer serializer )
throws Exception
{
if ( repository != null )
{
@ -772,7 +784,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeResource( Resource resource, String tagName, XmlSerializer serializer ) throws Exception
private void writeResource( Resource resource, String tagName, XmlSerializer serializer )
throws Exception
{
if ( resource != null )
{
@ -824,7 +837,8 @@ public class MavenXpp3Writer
* @param tagName
*/
private void writeSourceModification( SourceModification sourceModification, String tagName,
XmlSerializer serializer ) throws Exception
XmlSerializer serializer )
throws Exception
{
if ( sourceModification != null )
{
@ -875,7 +889,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeUnitTest( UnitTest unitTest, String tagName, XmlSerializer serializer ) throws Exception
private void writeUnitTest( UnitTest unitTest, String tagName, XmlSerializer serializer )
throws Exception
{
if ( unitTest != null )
{
@ -921,7 +936,8 @@ public class MavenXpp3Writer
* @param serializer
* @param tagName
*/
private void writeVersion( Version version, String tagName, XmlSerializer serializer ) throws Exception
private void writeVersion( Version version, String tagName, XmlSerializer serializer )
throws Exception
{
if ( version != null )
{

View File

@ -136,15 +136,14 @@ public class Main
RepositoryCleanerConfiguration config = new RepositoryCleanerConfiguration();
config.setSourceRepositoryPath( props.getProperty( "sourceRepositoryPath" ) );
config.setSourceRepositoryLayout( props.getProperty( "sourceRepositoryLayout", "legacy" ) );
config.setSourcePomVersion( props.getProperty( "sourcePomVersion", "v3" ) );
config.setTargetRepositoryPath( props.getProperty( "targetRepositoryPath" ) );
config.setTargetRepositoryLayout( props.getProperty( "targetRepositoryLayout", "default" ) );
config.setReportsPath( props.getProperty( "reportsPath" ) );
config.setBlacklistedPatterns( props.getProperty( "blacklistedPatterns" ) );
config.setReportOnly( Boolean.valueOf( props.getProperty( "reportOnly" ) ).booleanValue() );
config.setMailErrorReport(
Boolean.valueOf( props.getProperty( "errorReport.mailOnError", "false" ) ).booleanValue() );
config.setMailErrorReport( Boolean.valueOf( props.getProperty( "errorReport.mailOnError", "false" ) )
.booleanValue() );
config.setErrorReportFromAddress( props.getProperty( "errorReport.fromAddress" ) );
config.setErrorReportFromName( props.getProperty( "errorReport.fromName" ) );
config.setErrorReportSubject( props.getProperty( "errorReport.subject" ) );
@ -157,25 +156,34 @@ public class Main
private static void printHelp()
{
System.out.println( "repoclean: Repository Cleaner/Converter.\n\n" +
"Usage: repoclean -h|-template|<configuration-properties-file>\n\n" +
"---------------------------------------------------------------------------\n" +
" Use the '-template' option to see sample configuration file options.\n" + "\n" );
System.out.println( "repoclean: Repository Cleaner/Converter.\n\n"
+ "Usage: repoclean -h|-template|<configuration-properties-file>\n\n"
+ "---------------------------------------------------------------------------\n"
+ " Use the '-template' option to see sample configuration file options.\n" + "\n" );
}
private static void printTemplate()
{
System.out.println( "# ---------------------------------------------------------------------------\n" +
"# repoclean: Repository Cleaner/Converter.\n" + "# This configuration auto-generated on: " + new java.util.Date() + "\n" +
"# ---------------------------------------------------------------------------\n\n" +
"# [REQUIRED OPTIONS]\n" + "sourceRepositoryPath=/path/to/repository/root\n" + "targetRepositoryPath=/path/to/repository/root\n" + "reportsPath=/path/to/reports/directory\n" + "reportOnly=[true|false]\n" + "\n" + "errorReport.mailOnError=[true|false]\n" + "errorReport.fromAddress=admin@somewhere.com\n" + "errorReport.fromName=Admin\n" + "errorReport.subject=[REPOCLEAN] Error!\n" + "errorReport.toAddress=dev@somewhere.com\n" + "errorReport.toName=Developers List\n" + "\n" + "# [DEFAULT VALUE: legacy]\n" + "#sourceRepositoryLayout=[legacy|default]\n\n" + "# [DEFAULT VALUE: v3]\n" + "#sourcePomType=[v3|v4]\n\n" + "# [DEFAULT VALUE: default]\n" + "#targetRepositoryLayout=[legacy|default]\n" + "# [DEFAULT VALUE: localhost]\n" + "#errorReport.smtpHost=<hostname>\n" + "\n" );
System.out.println( "# ---------------------------------------------------------------------------\n"
+ "# repoclean: Repository Cleaner/Converter.\n" + "# This configuration auto-generated on: "
+ new java.util.Date() + "\n"
+ "# ---------------------------------------------------------------------------\n\n"
+ "# [REQUIRED OPTIONS]\n" + "sourceRepositoryPath=/path/to/repository/root\n"
+ "targetRepositoryPath=/path/to/repository/root\n" + "reportsPath=/path/to/reports/directory\n"
+ "reportOnly=[true|false]\n" + "\n" + "errorReport.mailOnError=[true|false]\n"
+ "errorReport.fromAddress=admin@somewhere.com\n" + "errorReport.fromName=Admin\n"
+ "errorReport.subject=[REPOCLEAN] Error!\n" + "errorReport.toAddress=dev@somewhere.com\n"
+ "errorReport.toName=Developers List\n" + "\n" + "# [DEFAULT VALUE: legacy]\n"
+ "#sourceRepositoryLayout=[legacy|default]\n\n" + "# [DEFAULT VALUE: v3]\n"
+ "# [DEFAULT VALUE: default]\n" + "#targetRepositoryLayout=[legacy|default]\n"
+ "# [DEFAULT VALUE: localhost]\n" + "#errorReport.smtpHost=<hostname>\n" + "\n" );
}
private static void printUsage()
{
System.out.println( "Required input is missing.\n\n" + "Usage:\n" +
"--------------------------------------------------\n\n" +
"repoclean -h|-template|<configuration-properties-file>\n" );
System.out.println( "Required input is missing.\n\n" + "Usage:\n"
+ "--------------------------------------------------\n\n"
+ "repoclean -h|-template|<configuration-properties-file>\n" );
}
}

View File

@ -15,21 +15,12 @@ package org.apache.maven.tools.repoclean;
* the License. ====================================================================
*/
import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.metadata.ArtifactMetadata;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
import org.apache.maven.tools.repoclean.artifact.metadata.ProjectMetadata;
import org.apache.maven.tools.repoclean.digest.DigestVerifier;
import org.apache.maven.tools.repoclean.discover.ArtifactDiscoverer;
import org.apache.maven.tools.repoclean.index.ArtifactIndexer;
import org.apache.maven.tools.repoclean.phase.DiscoveryPhase;
import org.apache.maven.tools.repoclean.phase.RewritePhase;
import org.apache.maven.tools.repoclean.report.FileReporter;
import org.apache.maven.tools.repoclean.report.PathLister;
import org.apache.maven.tools.repoclean.report.ReportWriteException;
import org.apache.maven.tools.repoclean.report.Reporter;
import org.apache.maven.tools.repoclean.rewrite.ArtifactPomRewriter;
import org.apache.maven.tools.repoclean.transaction.RewriteTransaction;
import org.apache.maven.tools.repoclean.transaction.RollbackException;
import org.codehaus.plexus.PlexusConstants;
import org.codehaus.plexus.PlexusContainer;
import org.codehaus.plexus.context.Context;
@ -40,39 +31,32 @@ import org.codehaus.plexus.mailsender.MailMessage;
import org.codehaus.plexus.mailsender.MailSender;
import org.codehaus.plexus.mailsender.MailSenderException;
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
import org.codehaus.plexus.util.IOUtil;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Iterator;
import java.util.List;
/**
* @author jdcasey
*/
public class RepositoryCleaner extends AbstractLogEnabled implements Contextualizable
public class RepositoryCleaner
extends AbstractLogEnabled
implements Contextualizable
{
public static final String ROLE = RepositoryCleaner.class.getName();
private static final String REPORTS_DIR_DATE_FORMAT = "dd-MMM-yyyy_hh.mm.ss";
private DigestVerifier digestVerifier;
private ArtifactRepositoryLayout bridgingLayout;
private MailSender mailSender;
private ArtifactIndexer artifactIndexer;
private DiscoveryPhase discoveryPhase;
private RewritePhase rewritePhase;
private PlexusContainer container;
private String dateSubdir;
@ -97,90 +81,41 @@ public class RepositoryCleaner extends AbstractLogEnabled implements Contextuali
{
repoReporter = new FileReporter( reportsBase, "repository.report.txt" );
ArtifactDiscoverer artifactDiscoverer = null;
List artifacts;
List artifacts = null;
artifacts = discoveryPhase.execute( reportsBase, sourceRepositoryBase, configuration, repoReporter );
PathLister kickoutLister = null;
PathLister excludeLister = null;
try
{
artifactDiscoverer = (ArtifactDiscoverer) container.lookup( ArtifactDiscoverer.ROLE,
configuration.getSourceRepositoryLayout() );
if ( logger.isDebugEnabled() )
{
logger.debug( "Discovering artifacts." );
}
try
{
File kickoutsList = new File( reportsBase, "kickouts.txt" );
File excludesList = new File( reportsBase, "excludes.txt" );
kickoutLister = new PathLister( kickoutsList );
excludeLister = new PathLister( excludesList );
artifacts = artifactDiscoverer.discoverArtifacts( sourceRepositoryBase, repoReporter,
configuration.getBlacklistedPatterns(),
excludeLister, kickoutLister );
}
catch ( Exception e )
{
repoReporter.error( "Error discovering artifacts in source repository.", e );
throw e;
}
}
finally
{
if ( artifactDiscoverer != null )
{
container.release( artifactDiscoverer );
}
if ( excludeLister != null )
{
excludeLister.close();
}
if ( kickoutLister != null )
{
kickoutLister.close();
}
}
if ( artifacts != null )
if ( !artifacts.isEmpty() )
{
ArtifactRepositoryLayout sourceLayout = null;
ArtifactRepositoryLayout targetLayout = null;
try
{
sourceLayout = (ArtifactRepositoryLayout) container.lookup( ArtifactRepositoryLayout.ROLE,
configuration.getSourceRepositoryLayout() );
configuration
.getSourceRepositoryLayout() );
ArtifactRepository sourceRepo = new ArtifactRepository( "source", "file://" +
sourceRepositoryBase.getAbsolutePath(),
sourceLayout );
ArtifactRepository sourceRepo = new ArtifactRepository( "source", "file://"
+ sourceRepositoryBase.getAbsolutePath(), sourceLayout );
targetLayout = (ArtifactRepositoryLayout) container.lookup( ArtifactRepositoryLayout.ROLE,
configuration.getTargetRepositoryLayout() );
configuration
.getTargetRepositoryLayout() );
ArtifactRepository targetRepo = new ArtifactRepository( "target", "file://" +
targetRepositoryBase.getAbsolutePath(),
targetLayout );
ArtifactRepository targetRepo = new ArtifactRepository( "target", "file://"
+ targetRepositoryBase.getAbsolutePath(), targetLayout );
if ( logger.isDebugEnabled() )
{
logger.debug( "Rewriting POMs and artifact files." );
}
artifactIndexer.writeAritfactIndex( artifacts, targetRepositoryBase );
// List originalArtifacts = new ArrayList( artifacts );
rewriteArtifactsAndPoms( artifacts, sourceRepo, targetRepo, configuration, reportsBase,
sourceRepositoryBase, targetRepositoryBase, repoReporter );
List rewritten = rewritePhase.execute( artifacts, sourceRepo, targetRepo, configuration,
reportsBase, repoReporter );
artifactIndexer.writeAritfactIndex( rewritten, targetRepositoryBase );
}
finally
{
@ -203,8 +138,8 @@ public class RepositoryCleaner extends AbstractLogEnabled implements Contextuali
if ( repoReporter.hasWarning() && logger.isDebugEnabled() )
{
logger.debug(
"Warning encountered while rewriting one or more artifacts from source repository to target repository." );
logger
.warn( "Warning encountered while rewriting one or more artifacts from source repository to target repository." );
}
}
finally
@ -215,7 +150,8 @@ public class RepositoryCleaner extends AbstractLogEnabled implements Contextuali
}
}
// if we wrote a repository report, and the configuration says to email the report, then do it.
// if we wrote a repository report with an error in it, and the configuration says to email the report,
// then do it.
if ( repoReporter.hasError() && configuration.mailErrorReport() )
{
logger.debug( "Sending error report to " + configuration.getErrorReportToName() + " via email." );
@ -224,8 +160,8 @@ public class RepositoryCleaner extends AbstractLogEnabled implements Contextuali
StringBuffer contentBuffer = new StringBuffer();
contentBuffer.append( "Errors occurred while performing maven-1 to maven-2 repository conversion.\n\n" +
"For more details, see:\n\n" );
contentBuffer.append( "Errors occurred while performing maven-1 to maven-2 repository conversion.\n\n"
+ "For more details, see:\n\n" );
contentBuffer.append( configuration.getErrorReportLink().replaceAll( "#date", dateSubdir ) );
@ -250,286 +186,6 @@ public class RepositoryCleaner extends AbstractLogEnabled implements Contextuali
}
private void rewriteArtifactsAndPoms( List artifacts, ArtifactRepository sourceRepo, ArtifactRepository targetRepo,
RepositoryCleanerConfiguration configuration, File reportsBase,
File sourceRepositoryBase, File targetRepositoryBase,
FileReporter repoReporter )
throws Exception
{
Logger logger = getLogger();
ArtifactPomRewriter artifactPomRewriter = null;
try
{
logger.debug( "Rewriting up to " + artifacts.size() + " artifacts (Should be " + ( artifacts.size() * 2 ) +
" rewrites including POMs)." );
int actualRewriteCount = 0;
for ( Iterator it = artifacts.iterator(); it.hasNext(); )
{
Artifact artifact = (Artifact) it.next();
RewriteTransaction transaction = new RewriteTransaction( artifact );
String artifactReportPath = buildArtifactReportPath( artifact );
FileReporter artifactReporter = null;
try
{
artifactReporter = new FileReporter( reportsBase, artifactReportPath );
boolean errorOccurred = false;
File artifactSource = new File( sourceRepo.getBasedir(), sourceRepo.pathOf( artifact ) );
File artifactTarget = new File( targetRepo.getBasedir(), targetRepo.pathOf( artifact ).replace(
'+', '-' ) );
transaction.addFile( artifactTarget );
artifact.setFile( artifactSource );
boolean targetMissingOrOlder = !artifactTarget.exists() ||
artifactTarget.lastModified() < artifactSource.lastModified();
if ( artifactSource.exists() && ( configuration.force() || targetMissingOrOlder ) )
{
actualRewriteCount++;
transaction.addFile( artifactTarget );
try
{
if ( !configuration.reportOnly() )
{
if ( logger.isDebugEnabled() )
{
logger.debug( "sourceRepo basedir is: \'" + sourceRepo.getBasedir() + "\'" );
logger.debug( "targetRepo basedir is: \'" + targetRepo.getBasedir() + "\'" );
}
File targetParent = artifactTarget.getParentFile();
if ( !targetParent.exists() )
{
targetParent.mkdirs();
}
if ( logger.isDebugEnabled() )
{
logger.debug( "Copying artifact[" + artifact.getId() + "] from \'" +
artifactSource + "\' to \'" + artifactTarget + "\'." );
}
copyArtifact( artifact, artifactTarget, artifactReporter );
}
}
catch ( Exception e )
{
repoReporter.error( "Error transferring artifact[" + artifact.getId() +
"] to the target repository.", e );
throw e;
}
if ( logger.isDebugEnabled() )
{
logger.debug( "working on digest for artifact[" + artifact.getId() + "] with groupId: \'" +
artifact.getGroupId() + "\'" );
}
try
{
digestVerifier.verifyDigest( artifactSource, artifactTarget, transaction, artifactReporter,
configuration.reportOnly() );
}
catch ( Exception e )
{
repoReporter.error( "Error verifying digest for artifact[" + artifact.getId() + "]", e );
throw e;
}
ArtifactMetadata pom = new ProjectMetadata( artifact );
artifactPomRewriter = (ArtifactPomRewriter) container.lookup( ArtifactPomRewriter.ROLE,
configuration.getSourcePomVersion() );
File sourcePom = new File( sourceRepositoryBase, sourceRepo.pathOfMetadata( pom ) );
File targetPom = new File( targetRepositoryBase,
targetRepo.pathOfMetadata( pom ).replace( '+', '-' ) );
transaction.addFile( targetPom );
File bridgedTargetPom = new File( targetRepositoryBase, bridgingLayout.pathOfMetadata( pom ).replace(
'+', '-' ) );
transaction.addFile( bridgedTargetPom );
try
{
artifactPomRewriter.rewrite( artifact, sourcePom, targetPom, artifactReporter,
configuration.reportOnly() );
boolean wroteBridge = bridgePomLocations( targetPom, bridgedTargetPom, artifactReporter );
digestVerifier.verifyDigest( sourcePom, targetPom, transaction, artifactReporter,
configuration.reportOnly() );
if ( wroteBridge )
{
digestVerifier.verifyDigest( sourcePom, bridgedTargetPom, transaction,
artifactReporter, configuration.reportOnly() );
}
}
catch ( Exception e )
{
repoReporter.error( "Error rewriting POM for artifact[" + artifact.getId() +
"] into the target repository.\n Error message: " + e.getMessage() );
throw e;
}
}
else if ( !targetMissingOrOlder )
{
artifactReporter.warn( "Target file for artifact is present and not stale. (Artifact: \'" +
artifact.getId() + "\' in path: \'" + artifactSource +
"\' with target path: " + artifactTarget + ")." );
}
else
{
artifactReporter.error( "Cannot find source file for artifact: \'" + artifact.getId() +
"\' under path: \'" + artifactSource + "\'" );
}
if ( artifactReporter.hasError() )
{
repoReporter.warn( "Error(s) occurred while rewriting artifact: \'" + artifact.getId() +
"\' or its POM." );
}
}
catch ( Exception e )
{
if ( !configuration.force() )
{
repoReporter.warn( "Rolling back conversion for: " + artifact );
try
{
transaction.rollback();
}
catch ( RollbackException re )
{
repoReporter.error( "Error rolling back conversion transaction.", re );
}
}
else
{
repoReporter.warn( "NOT Rolling back conversion for: " + artifact + "; we are in --force mode." );
}
artifactReporter.error( "Error while rewriting file or POM for artifact: \'" + artifact.getId() +
"\'. See report at: \'" + artifactReportPath + "\'.", e );
}
finally
{
if ( artifactReporter != null )
{
artifactReporter.close();
}
}
}
logger.info( "Actual number of artifacts rewritten: " + actualRewriteCount + " (" +
( actualRewriteCount * 2 ) + " including POMs)." );
}
finally
{
if ( artifactPomRewriter != null )
{
container.release( artifactPomRewriter );
}
}
}
private boolean bridgePomLocations( File targetPom, File bridgedTargetPom, Reporter reporter )
throws IOException, ReportWriteException
{
if ( targetPom.equals( bridgedTargetPom ) )
{
reporter.warn( "Cannot create legacy-compatible copy of POM at: " + targetPom +
"; legacy-compatible path is the same as the converted POM itself." );
return false;
}
FileInputStream in = null;
FileOutputStream out = null;
try
{
in = new FileInputStream( targetPom );
out = new FileOutputStream( bridgedTargetPom );
IOUtil.copy( in, out );
}
finally
{
IOUtil.close( in );
IOUtil.close( out );
}
return true;
}
private String buildArtifactReportPath( Artifact artifact )
{
String classifier = artifact.getClassifier();
String groupId = artifact.getGroupId().replace( '.', '/' );
String artifactId = artifact.getArtifactId();
String type = artifact.getType();
String version = artifact.getVersion();
return groupId + "/" + artifactId + "/" + type + "/" +
( ( classifier != null ) ? ( classifier + "-" ) : ( "" ) ) + version + ".report.txt";
}
private void copyArtifact( Artifact artifact, File artifactTarget, FileReporter reporter )
throws IOException
{
File artifactSource = artifact.getFile();
InputStream inStream = null;
OutputStream outStream = null;
try
{
File targetParent = artifactTarget.getParentFile();
if ( !targetParent.exists() )
{
targetParent.mkdirs();
}
inStream = new BufferedInputStream( new FileInputStream( artifactSource ) );
outStream = new BufferedOutputStream( new FileOutputStream( artifactTarget ) );
byte[] buffer = new byte[16];
int read = -1;
while ( ( read = inStream.read( buffer ) ) > -1 )
{
outStream.write( buffer, 0, read );
}
outStream.flush();
}
finally
{
IOUtil.close( inStream );
IOUtil.close( outStream );
}
}
private File normalizeTargetRepositoryBase( String targetRepositoryPath )
{
Logger logger = getLogger();
@ -546,8 +202,8 @@ public class RepositoryCleaner extends AbstractLogEnabled implements Contextuali
}
else if ( !targetRepositoryBase.isDirectory() )
{
logger.error( "Cannot write to target repository \'" + targetRepositoryBase +
"\' because it is not a directory." );
logger.error( "Cannot write to target repository \'" + targetRepositoryBase
+ "\' because it is not a directory." );
targetRepositoryBase = null;
}

View File

@ -27,8 +27,6 @@ public class RepositoryCleanerConfiguration
private String sourceRepositoryLayout;
private String sourcePomVersion;
private String targetRepositoryPath;
private String targetRepositoryLayout;
@ -75,16 +73,6 @@ public class RepositoryCleanerConfiguration
return sourceRepositoryLayout;
}
public void setSourcePomVersion( String sourcePomVersion )
{
this.sourcePomVersion = sourcePomVersion;
}
public String getSourcePomVersion()
{
return sourcePomVersion;
}
public void setTargetRepositoryPath( String targetRepositoryPath )
{
this.targetRepositoryPath = targetRepositoryPath;

View File

@ -22,7 +22,8 @@ import org.apache.maven.artifact.handler.AbstractArtifactHandler;
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
* @version $Id$
*/
public class DtdHandler extends AbstractArtifactHandler
public class DtdHandler
extends AbstractArtifactHandler
{
public String directory()
{

View File

@ -22,7 +22,8 @@ import org.apache.maven.artifact.handler.JarHandler;
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
* @version $Id$
*/
public class EarHandler extends JarHandler
public class EarHandler
extends JarHandler
{
public String directory()
{

View File

@ -19,7 +19,8 @@ import org.apache.maven.artifact.handler.AbstractArtifactHandler;
/**
* @author jdcasey
*/
public class JarDistroHandler extends AbstractArtifactHandler
public class JarDistroHandler
extends AbstractArtifactHandler
{
public String directory()

View File

@ -22,7 +22,8 @@ import org.apache.maven.artifact.handler.AbstractArtifactHandler;
/**
* @author jdcasey
*/
public class LegacyPluginHandler extends AbstractArtifactHandler
public class LegacyPluginHandler
extends AbstractArtifactHandler
{
public String directory()

View File

@ -22,7 +22,8 @@ import org.apache.maven.artifact.handler.JarHandler;
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
* @version $Id$
*/
public class RarHandler extends JarHandler
public class RarHandler
extends JarHandler
{
public String directory()
{

View File

@ -22,7 +22,8 @@ import org.apache.maven.artifact.handler.JarHandler;
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
* @version $Id$
*/
public class SarHandler extends JarHandler
public class SarHandler
extends JarHandler
{
public String directory()
{

View File

@ -19,7 +19,8 @@ import org.apache.maven.artifact.handler.AbstractArtifactHandler;
/**
* @author jdcasey
*/
public class TgzDistroHandler extends AbstractArtifactHandler
public class TgzDistroHandler
extends AbstractArtifactHandler
{
public String directory()

View File

@ -22,7 +22,8 @@ import org.apache.maven.artifact.handler.AbstractArtifactHandler;
* @author <a href="mailto:jason@maven.org">Jason van Zyl</a>
* @version $Id$
*/
public class TldHandler extends AbstractArtifactHandler
public class TldHandler
extends AbstractArtifactHandler
{
public String directory()
{

View File

@ -19,7 +19,8 @@ import org.apache.maven.artifact.handler.AbstractArtifactHandler;
/**
* @author jdcasey
*/
public class ZipDistroHandler extends AbstractArtifactHandler
public class ZipDistroHandler
extends AbstractArtifactHandler
{
public String directory()

View File

@ -21,7 +21,8 @@ import org.apache.maven.artifact.repository.layout.DefaultRepositoryLayout;
* limitations under the License.
*/
public class AlphaBridgingRepositoryLayout extends DefaultRepositoryLayout
public class AlphaBridgingRepositoryLayout
extends DefaultRepositoryLayout
{
public String pathOfMetadata( ArtifactMetadata metadata )

View File

@ -28,7 +28,8 @@ import org.apache.maven.artifact.repository.ArtifactRepository;
* @author <a href="mailto:brett@apache.org">Brett Porter</a>
* @version $Id$
*/
public class ProjectMetadata implements ArtifactMetadata
public class ProjectMetadata
implements ArtifactMetadata
{
private final Artifact artifact;

View File

@ -20,7 +20,8 @@ package org.apache.maven.tools.repoclean.digest;
/**
* @author jdcasey
*/
public class DigestException extends Exception
public class DigestException
extends Exception
{
public DigestException( String message )

View File

@ -20,7 +20,8 @@ package org.apache.maven.tools.repoclean.digest;
/**
* @author jdcasey
*/
public class DigestVerificationException extends Exception
public class DigestVerificationException
extends Exception
{
public DigestVerificationException()

View File

@ -78,8 +78,8 @@ public class DigestVerifier
}
catch ( IOException e )
{
reporter.error( "Cannot copy digest file for path [" + artifactSource +
"] from source to target for digest algorithm: \'" + digestAlgorithm + "\'.", e );
reporter.error( "Cannot copy digest file for path [" + artifactSource
+ "] from source to target for digest algorithm: \'" + digestAlgorithm + "\'.", e );
throw e;
}

View File

@ -68,8 +68,8 @@ public class Digestor
}
catch ( IOException e )
{
throw new DigestException( "Cannot verify digest for artifact file: \'" + artifactFile +
"\' against digest file: \'" + digestFile + "\' using algorithm: \'" + algorithm + "\'", e );
throw new DigestException( "Cannot verify digest for artifact file: \'" + artifactFile
+ "\' against digest file: \'" + digestFile + "\' using algorithm: \'" + algorithm + "\'", e );
}
finally
{

View File

@ -23,11 +23,12 @@ import java.io.File;
* limitations under the License.
*/
public abstract class AbstractArtifactDiscoverer extends AbstractLogEnabled implements ArtifactDiscoverer
public abstract class AbstractArtifactDiscoverer
extends AbstractLogEnabled
implements ArtifactDiscoverer
{
protected String[] scanForArtifactPaths( File repositoryBase, String blacklistedPatterns,
PathLister excludesLister )
protected String[] scanForArtifactPaths( File repositoryBase, String blacklistedPatterns, PathLister excludesLister )
throws ReportWriteException
{
String[] blacklisted = null;

View File

@ -27,12 +27,27 @@ public interface ArtifactDiscoverer
{
public static final String ROLE = ArtifactDiscoverer.class.getName();
public static final String[] STANDARD_DISCOVERY_EXCLUDES = {"bin/**", "reports/**", ".maven/**", "**/poms/*.pom",
"**/*.md5", "**/*.MD5", "**/*.sha1", "**/*.SHA1",
"**/*snapshot-version", "*/website/**",
"*/licenses/**", "*/licences/**", "**/.htaccess",
"**/*.html", "**/*.asc", "**/*.txt", "**/*.xml",
"**/README*", "**/CHANGELOG*", "**/KEYS*"};
public static final String[] STANDARD_DISCOVERY_EXCLUDES = {
"bin/**",
"reports/**",
".maven/**",
"**/poms/*.pom",
"**/*.md5",
"**/*.MD5",
"**/*.sha1",
"**/*.SHA1",
"**/*snapshot-version",
"*/website/**",
"*/licenses/**",
"*/licences/**",
"**/.htaccess",
"**/*.html",
"**/*.asc",
"**/*.txt",
"**/*.xml",
"**/README*",
"**/CHANGELOG*",
"**/KEYS*" };
List discoverArtifacts( File repositoryBase, Reporter reporter, String blacklistedPatterns,
PathLister excludeLister, PathLister kickoutLister )

View File

@ -29,7 +29,8 @@ import java.util.StringTokenizer;
/**
* @author jdcasey
*/
public class DefaultArtifactDiscoverer extends AbstractArtifactDiscoverer
public class DefaultArtifactDiscoverer
extends AbstractArtifactDiscoverer
{
private ArtifactFactory artifactFactory;

View File

@ -30,7 +30,8 @@ import java.util.StringTokenizer;
/**
* @author jdcasey
*/
public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
public class LegacyArtifactDiscoverer
extends AbstractArtifactDiscoverer
{
private ArtifactFactory artifactFactory;
@ -133,13 +134,13 @@ public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
}
}
String validVersionParts = "([Dd][Ee][Vv][_.0-9]*)|" + "([Ss][Nn][Aa][Pp][Ss][Hh][Oo][Tt])|" +
"([0-9][_.0-9a-zA-Z]*)|" + "([Gg]?[_.0-9ab]*([Pp][Rr][Ee]|[Rr][Cc]|[Gg]|[Mm])[_.0-9]*)|" +
"([Aa][Ll][Pp][Hh][Aa][_.0-9]*)|" + "([Bb][Ee][Tt][Aa][_.0-9]*)|" + "([Rr][Cc][_.0-9]*)|" +
"([Tt][Ee][Ss][Tt][_.0-9]*)|" + "([Dd][Ee][Bb][Uu][Gg][_.0-9]*)|" +
"([Uu][Nn][Oo][Ff][Ff][Ii][Cc][Ii][Aa][Ll][_.0-9]*)|" + "([Cc][Uu][Rr][Rr][Ee][Nn][Tt])|" +
"([Ll][Aa][Tt][Ee][Ss][Tt])|" + "([Ff][Cc][Ss])|" + "([Rr][Ee][Ll][Ee][Aa][Ss][Ee][_.0-9]*)|" +
"([Nn][Ii][Gg][Hh][Tt][Ll][Yy])";
String validVersionParts = "([Dd][Ee][Vv][_.0-9]*)|" + "([Ss][Nn][Aa][Pp][Ss][Hh][Oo][Tt])|"
+ "([0-9][_.0-9a-zA-Z]*)|" + "([Gg]?[_.0-9ab]*([Pp][Rr][Ee]|[Rr][Cc]|[Gg]|[Mm])[_.0-9]*)|"
+ "([Aa][Ll][Pp][Hh][Aa][_.0-9]*)|" + "([Bb][Ee][Tt][Aa][_.0-9]*)|" + "([Rr][Cc][_.0-9]*)|"
+ "([Tt][Ee][Ss][Tt][_.0-9]*)|" + "([Dd][Ee][Bb][Uu][Gg][_.0-9]*)|"
+ "([Uu][Nn][Oo][Ff][Ff][Ii][Cc][Ii][Aa][Ll][_.0-9]*)|" + "([Cc][Uu][Rr][Rr][Ee][Nn][Tt])|"
+ "([Ll][Aa][Tt][Ee][Ss][Tt])|" + "([Ff][Cc][Ss])|" + "([Rr][Ee][Ll][Ee][Aa][Ss][Ee][_.0-9]*)|"
+ "([Nn][Ii][Gg][Hh][Tt][Ll][Yy])";
// let's discover the version, and whatever's leftover will be either
// a classifier, or part of the artifactId, depending on position.
@ -196,15 +197,17 @@ public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
tokensIterated++;
}
getLogger().debug( "After parsing loop, state of buffers:\no Version Buffer: \'" + versionBuffer +
"\'\no Classifier Buffer: \'" + classifierBuffer +
"\'\no Number of Tokens Iterated: " + tokensIterated );
getLogger().debug(
"After parsing loop, state of buffers:\no Version Buffer: \'" + versionBuffer
+ "\'\no Classifier Buffer: \'" + classifierBuffer
+ "\'\no Number of Tokens Iterated: " + tokensIterated );
// Now, restore the proper ordering so we can build the artifactId.
Collections.reverse( avceTokenList );
getLogger().debug( "Before repairing bad version and/or cleaning up used tokens, avce token list is:\n" +
avceTokenList );
getLogger().debug(
"Before repairing bad version and/or cleaning up used tokens, avce token list is:\n"
+ avceTokenList );
// if we didn't find a version, then punt. Use the last token
// as the version, and set the classifier empty.
@ -220,8 +223,9 @@ public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
else
{
getLogger().debug( "Cannot parse version from artifact path: \'" + path + "\'." );
getLogger().debug( "artifact-version-classifier-extension remaining tokens is: \'" + avceTokenList +
"\'" );
getLogger().debug(
"artifact-version-classifier-extension remaining tokens is: \'" + avceTokenList
+ "\'" );
}
classifierBuffer.setLength( 0 );
@ -232,8 +236,7 @@ public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
// if everything is kosher, then pop off all the classifier and
// version tokens, leaving the naked artifact id in the list.
avceTokenList =
new LinkedList( avceTokenList.subList( 0, avceTokenList.size() - ( tokensIterated ) ) );
avceTokenList = new LinkedList( avceTokenList.subList( 0, avceTokenList.size() - ( tokensIterated ) ) );
}
getLogger().debug( "Now, remainder of avce token list is:\n" + avceTokenList );
@ -272,10 +275,11 @@ public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
version = null;
}
getLogger().debug( "Extracted artifact information from path:\n" + "groupId: \'" + groupId + "\'\n" +
"artifactId: \'" + artifactId + "\'\n" + "type: \'" + type + "\'\n" +
"version: \'" + version + "\'\n" + "classifier: \'" + classifierBuffer.toString() +
"\'" );
getLogger().debug(
"Extracted artifact information from path:\n" + "groupId: \'" + groupId + "\'\n"
+ "artifactId: \'" + artifactId + "\'\n" + "type: \'" + type + "\'\n"
+ "version: \'" + version + "\'\n" + "classifier: \'" + classifierBuffer.toString()
+ "\'" );
Artifact result = null;
@ -284,16 +288,17 @@ public class LegacyArtifactDiscoverer extends AbstractArtifactDiscoverer
getLogger().debug( "Creating artifact with classifier." );
result = artifactFactory.createArtifactWithClassifier( groupId, artifactId, version,
Artifact.SCOPE_RUNTIME, type,
classifierBuffer.toString() );
Artifact.SCOPE_RUNTIME, type, classifierBuffer
.toString() );
}
else
{
result = artifactFactory.createArtifact( groupId, artifactId, version, Artifact.SCOPE_RUNTIME, type );
}
getLogger().debug( "Resulting artifact is: " + result.getId() + " and has classifier of: " +
result.getClassifier() + "\n\n" );
getLogger().debug(
"Resulting artifact is: " + result.getId() + " and has classifier of: "
+ result.getClassifier() + "\n\n" );
return result;
}

View File

@ -32,7 +32,8 @@ import java.util.List;
/**
* @author jdcasey
*/
public class ArtifactIndexer extends AbstractLogEnabled
public class ArtifactIndexer
extends AbstractLogEnabled
{
public static final String ROLE = ArtifactIndexer.class.getName();
@ -64,7 +65,8 @@ public class ArtifactIndexer extends AbstractLogEnabled
}
}
private static final class ArtifactIdComparator implements Comparator
private static final class ArtifactIdComparator
implements Comparator
{
public int compare( Object first, Object second )

View File

@ -32,7 +32,8 @@ import java.util.List;
/**
* @author jdcasey
*/
public class FileReporter implements Reporter
public class FileReporter
implements Reporter
{
private static final String WARN_LEVEL = "[WARNING] ";
@ -61,9 +62,9 @@ public class FileReporter implements Reporter
if ( !parentDir.isDirectory() )
{
throw new IllegalArgumentException( "path: \'" + parentDir.getAbsolutePath() +
"\' refers to a file, not a directory.\n" + "Cannot write report file: \'" +
reportsFile.getAbsolutePath() + "\'." );
throw new IllegalArgumentException( "path: \'" + parentDir.getAbsolutePath()
+ "\' refers to a file, not a directory.\n" + "Cannot write report file: \'"
+ reportsFile.getAbsolutePath() + "\'." );
}
}
@ -170,7 +171,8 @@ public class FileReporter implements Reporter
return sWriter.toString();
}
private static class AppendingList extends ArrayList
private static class AppendingList
extends ArrayList
{
public AppendingList()
{

View File

@ -16,7 +16,8 @@ package org.apache.maven.tools.repoclean.report;
* limitations under the License.
*/
public class ReportWriteException extends Exception
public class ReportWriteException
extends Exception
{
public ReportWriteException( String message, Throwable cause )

View File

@ -1,9 +1,10 @@
package org.apache.maven.tools.repoclean.rewrite;
import org.apache.maven.artifact.Artifact;
import org.apache.maven.tools.repoclean.report.FileReporter;
import org.apache.maven.tools.repoclean.report.Reporter;
import java.io.File;
import java.io.Reader;
import java.io.Writer;
/* ====================================================================
* Copyright 2001-2004 The Apache Software Foundation.
@ -30,7 +31,11 @@ public interface ArtifactPomRewriter
public static final String ROLE = ArtifactPomRewriter.class.getName();
void rewrite( Artifact artifact, File from, File to, FileReporter reporter, boolean reportOnly )
public static final String V3_POM = "v3";
public static final String V4_POM = "v4";
void rewrite( Artifact artifact, Reader from, Writer to, Reporter reporter, boolean reportOnly )
throws Exception;
}

View File

@ -4,14 +4,12 @@ import org.apache.maven.artifact.Artifact;
import org.apache.maven.model.Model;
import org.apache.maven.model.io.xpp3.MavenXpp3Writer;
import org.apache.maven.model.v3_0_0.io.xpp3.MavenXpp3Reader;
import org.apache.maven.tools.repoclean.report.FileReporter;
import org.apache.maven.tools.repoclean.report.Reporter;
import org.apache.maven.tools.repoclean.translate.PomV3ToV4Translator;
import org.codehaus.plexus.util.IOUtil;
import org.codehaus.plexus.util.StringUtils;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.Reader;
import java.io.Writer;
/* ====================================================================
* Copyright 2001-2004 The Apache Software Foundation.
@ -33,28 +31,24 @@ import java.io.FileWriter;
/**
* @author jdcasey
*/
public class V3PomRewriter implements ArtifactPomRewriter
public class V3PomRewriter
implements ArtifactPomRewriter
{
private PomV3ToV4Translator translator;
public void rewrite( Artifact artifact, File from, File to, FileReporter reporter, boolean reportOnly )
public void rewrite( Artifact artifact, Reader from, Writer to, Reporter reporter, boolean reportOnly )
throws Exception
{
Model v4Model = null;
if ( from.exists() )
{
FileReader fromReader = null;
try
if( from != null )
{
org.apache.maven.model.v3_0_0.Model v3Model = null;
try
{
fromReader = new FileReader( from );
MavenXpp3Reader v3Reader = new MavenXpp3Reader();
v3Model = v3Reader.read( fromReader );
v3Model = v3Reader.read( from );
}
catch ( Exception e )
{
@ -68,16 +62,8 @@ public class V3PomRewriter implements ArtifactPomRewriter
v4Model = translator.translate( v3Model, reporter );
}
}
finally
{
IOUtil.close( fromReader );
}
}
else
{
reporter.warn( "POM for artifact[" + artifact.getId() +
"] does not exist in source repository. We will create a skeletal one here." );
v4Model = new Model();
}
@ -87,28 +73,13 @@ public class V3PomRewriter implements ArtifactPomRewriter
if ( !reportOnly )
{
File toParent = to.getParentFile();
if ( !toParent.exists() )
{
toParent.mkdirs();
}
FileWriter toWriter = null;
try
{
toWriter = new FileWriter( to );
MavenXpp3Writer v4Writer = new MavenXpp3Writer();
v4Writer.write( toWriter, v4Model );
}
finally
{
IOUtil.close( toWriter );
}
v4Writer.write( to, v4Model );
}
}
}
private void validateV4Basics( Model model, Artifact artifact, FileReporter reporter )
private void validateV4Basics( Model model, Artifact artifact, Reporter reporter )
throws Exception
{
if ( StringUtils.isEmpty( model.getModelVersion() ) )

View File

@ -21,50 +21,39 @@ import org.apache.maven.artifact.Artifact;
import org.apache.maven.model.Model;
import org.apache.maven.model.io.xpp3.MavenXpp3Reader;
import org.apache.maven.model.io.xpp3.MavenXpp3Writer;
import org.apache.maven.tools.repoclean.report.FileReporter;
import org.codehaus.plexus.util.IOUtil;
import org.apache.maven.tools.repoclean.report.Reporter;
import org.codehaus.plexus.util.StringUtils;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.Reader;
import java.io.Writer;
/**
* @author jdcasey
*/
public class V4PomRewriter implements ArtifactPomRewriter
public class V4PomRewriter
implements ArtifactPomRewriter
{
public void rewrite( Artifact artifact, File from, File to, FileReporter reporter, boolean reportOnly )
public void rewrite( Artifact artifact, Reader from, Writer to, Reporter reporter, boolean reportOnly )
throws Exception
{
Model model = null;
if ( from.exists() )
if( from != null )
{
FileReader fromReader = null;
try
{
fromReader = new FileReader( from );
MavenXpp3Reader reader = new MavenXpp3Reader();
try
{
model = reader.read( fromReader );
model = reader.read( from );
}
catch ( Exception e )
{
reporter.error( "Invalid v4 POM at \'" + from + "\'. Cannot read.", e );
}
}
finally
{
IOUtil.close( fromReader );
}
}
else
{
reporter.error( "POM for artifact[" + artifact.getId() + "] does not exist in source repository!" );
model = new Model();
}
if ( model != null )
@ -73,28 +62,13 @@ public class V4PomRewriter implements ArtifactPomRewriter
if ( !reportOnly )
{
File toParent = to.getParentFile();
if ( !toParent.exists() )
{
toParent.mkdirs();
}
FileWriter toWriter = null;
try
{
toWriter = new FileWriter( to );
MavenXpp3Writer writer = new MavenXpp3Writer();
writer.write( toWriter, model );
}
finally
{
IOUtil.close( toWriter );
}
writer.write( to, model );
}
}
}
private void validateBasics( Model model, Artifact artifact, FileReporter reporter )
private void validateBasics( Model model, Artifact artifact, Reporter reporter )
throws Exception
{
if ( StringUtils.isEmpty( model.getModelVersion() ) )

View File

@ -48,8 +48,8 @@ public class RewriteTransaction
File file = (File) it.next();
if ( file.exists() && !file.delete() )
{
throw new RollbackException( "[rollback] Cannot delete file: " + file +
"\nPart of transaction for artifact: {" + artifact.getId() + "}." );
throw new RollbackException( "[rollback] Cannot delete file: " + file
+ "\nPart of transaction for artifact: {" + artifact.getId() + "}." );
}
}
}

View File

@ -16,7 +16,8 @@ package org.apache.maven.tools.repoclean.transaction;
* limitations under the License.
*/
public class RollbackException extends Exception
public class RollbackException
extends Exception
{
public RollbackException( String message, Throwable cause )

View File

@ -20,7 +20,8 @@ package org.apache.maven.tools.repoclean.translate;
/**
* @author jdcasey
*/
public class PomTranslationException extends Exception
public class PomTranslationException
extends Exception
{
private final String groupId;

View File

@ -50,7 +50,8 @@ import java.util.regex.Pattern;
/**
* @author jdcasey
*/
public class PomV3ToV4Translator extends AbstractLogEnabled
public class PomV3ToV4Translator
extends AbstractLogEnabled
{
public static final String ROLE = PomV3ToV4Translator.class.getName();
@ -186,8 +187,8 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
if ( StringUtils.isNotEmpty( v3Model.getGumpRepositoryId() ) )
{
reporter.warn( "Ignoring gump repository id: \'" + v3Model.getGumpRepositoryId() +
"\'. This is not supported in v4 POMs." );
reporter.warn( "Ignoring gump repository id: \'" + v3Model.getGumpRepositoryId()
+ "\'. This is not supported in v4 POMs." );
}
if ( notEmpty( v3Model.getVersions() ) )
@ -261,8 +262,8 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
String reportPluginName = null;
if ( !matcher.matches() )
{
reporter.warn( "Non-standard report name: \'" + reportName +
"\'. Using entire name for plugin artifactId." );
reporter.warn( "Non-standard report name: \'" + reportName
+ "\'. Using entire name for plugin artifactId." );
reportPluginName = reportName;
}
@ -281,11 +282,11 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
StringBuffer info = new StringBuffer();
info.append( "Using some contrived information for report: \'" ).append( reportName ).append( "\'.\n" ).append(
"\to groupId: \'maven\'\n" ).append( "\to artifactId: \'" ).append( reportPluginName ).append(
"\'\n" ).append( "\to version: \'1.0-SNAPSHOT\'\n" ).append( "\to goal: \'report\'\n" ).append(
"\n" ).append(
"These values were extracted using the v3 report naming convention, but may be wrong." );
info.append( "Using some contrived information for report: \'" ).append( reportName ).append( "\'.\n" )
.append( "\to groupId: \'maven\'\n" ).append( "\to artifactId: \'" ).append( reportPluginName )
.append( "\'\n" ).append( "\to version: \'1.0-SNAPSHOT\'\n" ).append( "\to goal: \'report\'\n" )
.append( "\n" )
.append( "These values were extracted using the v3 report naming convention, but may be wrong." );
reporter.warn( info.toString() );
@ -303,7 +304,8 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
}
private org.apache.maven.model.Organization translateOrganization(
org.apache.maven.model.v3_0_0.Organization v3Organization, Reporter reporter )
org.apache.maven.model.v3_0_0.Organization v3Organization,
Reporter reporter )
throws ReportWriteException
{
Organization organization = null;
@ -332,7 +334,8 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
{
for ( Iterator it = v3MailingLists.iterator(); it.hasNext(); )
{
org.apache.maven.model.v3_0_0.MailingList v3List = (org.apache.maven.model.v3_0_0.MailingList) it.next();
org.apache.maven.model.v3_0_0.MailingList v3List = (org.apache.maven.model.v3_0_0.MailingList) it
.next();
MailingList list = new MailingList();
list.setArchive( v3List.getArchive() );
list.setName( v3List.getName() );
@ -481,7 +484,8 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
{
for ( Iterator it = v3Developers.iterator(); it.hasNext(); )
{
org.apache.maven.model.v3_0_0.Developer v3Developer = (org.apache.maven.model.v3_0_0.Developer) it.next();
org.apache.maven.model.v3_0_0.Developer v3Developer = (org.apache.maven.model.v3_0_0.Developer) it
.next();
Developer developer = new Developer();
@ -603,7 +607,8 @@ public class PomV3ToV4Translator extends AbstractLogEnabled
{
for ( Iterator it = v3Contributors.iterator(); it.hasNext(); )
{
org.apache.maven.model.v3_0_0.Contributor v3Contributor = (org.apache.maven.model.v3_0_0.Contributor) it.next();
org.apache.maven.model.v3_0_0.Contributor v3Contributor = (org.apache.maven.model.v3_0_0.Contributor) it
.next();
Contributor contributor = new Contributor();