import org.apache.lucene.document.NumberTools;
import org.apache.maven.repository.indexing.record.MinimalArtifactIndexRecord;
import org.apache.maven.repository.indexing.record.RepositoryIndexRecord;
+import org.codehaus.plexus.util.StringUtils;
/**
* Convert the minimal index record to a Lucene document.
DateTools.Resolution.SECOND ) );
addUntokenizedField( document, FLD_FILE_SIZE, NumberTools.longToString( standardIndexRecord.getSize() ) );
addUntokenizedField( document, FLD_MD5, standardIndexRecord.getMd5Checksum() );
- addTokenizedField( document, FLD_CLASSES, standardIndexRecord.getClasses() );
+ addTokenizedField( document, FLD_CLASSES,
+ StringUtils.join( standardIndexRecord.getClasses().iterator(), "\n" ) );
return document;
}
import org.apache.lucene.document.NumberTools;
import org.apache.maven.repository.indexing.record.RepositoryIndexRecord;
import org.apache.maven.repository.indexing.record.StandardArtifactIndexRecord;
+import org.codehaus.plexus.util.StringUtils;
/**
* Convert the standard index record to a Lucene document.
addUntokenizedField( document, FLD_FILE_SIZE, NumberTools.longToString( standardIndexRecord.getSize() ) );
addUntokenizedField( document, FLD_MD5, standardIndexRecord.getMd5Checksum() );
addUntokenizedField( document, FLD_SHA1, standardIndexRecord.getSha1Checksum() );
- addTokenizedField( document, FLD_CLASSES, standardIndexRecord.getClasses() );
- addTokenizedField( document, FLD_FILES, standardIndexRecord.getFiles() );
+ if ( standardIndexRecord.getClasses() != null )
+ {
+ addTokenizedField( document, FLD_CLASSES,
+ StringUtils.join( standardIndexRecord.getClasses().iterator(), "\n" ) );
+ }
+ if ( standardIndexRecord.getFiles() != null )
+ {
+ addTokenizedField( document, FLD_FILES,
+ StringUtils.join( standardIndexRecord.getFiles().iterator(), "\n" ) );
+ }
addTokenizedField( document, FLD_PLUGINPREFIX, standardIndexRecord.getPluginPrefix() );
addUntokenizedField( document, FLD_INCEPTION_YEAR, standardIndexRecord.getInceptionYear() );
addTokenizedField( document, FLD_PROJECT_NAME, standardIndexRecord.getProjectName() );
package org.apache.maven.repository.indexing.record;
import java.util.Date;
+import java.util.List;
/*
* Copyright 2005-2006 The Apache Software Foundation.
/**
* The classes in the archive for the artifact, if it is a JAR.
*/
- private String classes;
+ private List classes;
/**
* The MD5 checksum of the artifact file.
*/
private long size;
- public void setClasses( String classes )
+ public void setClasses( List classes )
{
this.classes = classes;
}
this.size = size;
}
- public String getClasses()
+ public List getClasses()
{
return classes;
}
import java.io.File;
import java.io.IOException;
+import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Iterator;
return record;
}
- private String getClassesFromFiles( List files )
+ private List getClassesFromFiles( List files )
{
- StringBuffer classes = new StringBuffer();
+ List classes = new ArrayList();
for ( Iterator i = files.iterator(); i.hasNext(); )
{
if ( isClass( name ) )
{
- classes.append( name.substring( 0, name.length() - 6 ).replace( '/', '.' ) ).append( "\n" );
+ classes.add( name.substring( 0, name.length() - 6 ).replace( '/', '.' ) );
}
}
- return classes.toString();
+ return classes;
}
}
package org.apache.maven.repository.indexing.record;
+import java.util.List;
+
/*
* Copyright 2005-2006 The Apache Software Foundation.
*
/**
* A list of files (separated by '\n') in the artifact if it is an archive.
*/
- private String files;
+ private List files;
/**
* The identifier of the repository that the artifact came from.
this.type = type;
}
- public void setFiles( String files )
+ public void setFiles( List files )
{
this.files = files;
}
return type;
}
- public String getFiles()
+ public List getFiles()
{
return files;
}
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;
+import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.HashSet;
private void populateArchiveEntries( List files, StandardArtifactIndexRecord record, File artifactFile )
throws RepositoryIndexException
{
- StringBuffer classes = new StringBuffer();
- StringBuffer fileBuffer = new StringBuffer();
+ List classes = new ArrayList();
+ List fileList = new ArrayList();
for ( Iterator i = files.iterator(); i.hasNext(); )
{
// ignore directories
if ( !name.endsWith( "/" ) )
{
- fileBuffer.append( name ).append( "\n" );
+ fileList.add( name );
if ( isClass( name ) )
{
- classes.append( name.substring( 0, name.length() - 6 ).replace( '/', '.' ) ).append( "\n" );
+ classes.add( name.substring( 0, name.length() - 6 ).replace( '/', '.' ) );
}
else if ( PLUGIN_METADATA_NAME.equals( name ) )
{
}
}
- if ( classes.length() > 0 )
+ if ( !classes.isEmpty() )
{
- record.setClasses( classes.toString() );
+ record.setClasses( classes );
}
- if ( fileBuffer.length() > 0 )
+ if ( !fileList.isEmpty() )
{
- record.setFiles( fileBuffer.toString() );
+ record.setFiles( fileList );
}
}
try
{
Document document = reader.document( 0 );
- assertRecord( document, artifact, "3a0adc365f849366cd8b633cad155cb7", "A\nb.B\nb.c.C\n" );
+ assertRecord( document, artifact, "3a0adc365f849366cd8b633cad155cb7", "A\nb.B\nb.c.C" );
assertEquals( "Check index size", 1, reader.numDocs() );
}
finally
try
{
Document document = reader.document( 0 );
- String expectedChecksum = "3a0adc365f849366cd8b633cad155cb7";
- String expectedClasses = "A\nb.B\nb.c.C\n";
- assertRecord( document, artifact, expectedChecksum, expectedClasses );
+ assertRecord( document, artifact, "3a0adc365f849366cd8b633cad155cb7", "A\nb.B\nb.c.C" );
assertEquals( "Check index size", 1, reader.numDocs() );
}
finally
{
Document document = reader.document( 0 );
assertRecord( document, artifact, "06f6fe25e46c4d4fb5be4f56a9bab0ee",
- "org.apache.maven.repository.record.MyMojo\n" );
+ "org.apache.maven.repository.record.MyMojo" );
assertEquals( "Check index size", 1, reader.numDocs() );
}
finally
{
assertRecord( artifact, document, "test-jar", "jar", "3a0adc365f849366cd8b633cad155cb7",
"c66f18bf192cb613fc2febb4da541a34133eedc2" );
- assertEquals( "Check document classes", "A\nb.B\nb.c.C\n", document.get( "classes" ) );
- assertEquals( "Check document files", "META-INF/MANIFEST.MF\nA.class\nb/B.class\nb/c/C.class\n",
+ assertEquals( "Check document classes", "A\nb.B\nb.c.C", document.get( "classes" ) );
+ assertEquals( "Check document files", "META-INF/MANIFEST.MF\nA.class\nb/B.class\nb/c/C.class",
document.get( "files" ) );
assertNull( "Check document inceptionYear", document.get( "inceptionYear" ) );
assertNull( "Check document projectName", document.get( "projectName" ) );
{
assertRecord( artifact, document, "test-plugin", "maven-plugin", "06f6fe25e46c4d4fb5be4f56a9bab0ee",
"382c1ebfb5d0c7d6061c2f8569fb53f8fc00fec2" );
- assertEquals( "Check document classes", "org.apache.maven.repository.record.MyMojo\n",
+ assertEquals( "Check document classes", "org.apache.maven.repository.record.MyMojo",
document.get( "classes" ) );
assertEquals( "Check document files", "META-INF/MANIFEST.MF\n" + "META-INF/maven/plugin.xml\n" +
"org/apache/maven/repository/record/MyMojo.class\n" +
"META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.xml\n" +
- "META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.properties\n", document.get( "files" ) );
+ "META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.properties", document.get( "files" ) );
assertEquals( "Check document pluginPrefix", "test", document.get( "pluginPrefix" ) );
assertEquals( "Check document packaging", "maven-plugin", document.get( "packaging" ) );
assertNull( "Check document inceptionYear", document.get( "inceptionYear" ) );
import java.io.File;
import java.io.IOException;
+import java.util.Arrays;
+import java.util.Collections;
+import java.util.List;
/**
* Test the minimal artifact index record.
private static final String TEST_GROUP_ID = "org.apache.maven.repository.record";
+ private static final List JAR_CLASS_LIST = Arrays.asList( new String[]{"A", "b.B", "b.c.C"} );
+
protected void setUp()
throws Exception
{
expectedRecord.setFilename( repository.pathOf( artifact ) );
expectedRecord.setLastModified( artifact.getFile().lastModified() );
expectedRecord.setSize( artifact.getFile().length() );
- expectedRecord.setClasses( "A\nb.B\nb.c.C\n" );
+ expectedRecord.setClasses( JAR_CLASS_LIST );
assertEquals( "check record", expectedRecord, record );
}
expectedRecord.setFilename( repository.pathOf( artifact ) );
expectedRecord.setLastModified( artifact.getFile().lastModified() );
expectedRecord.setSize( artifact.getFile().length() );
- expectedRecord.setClasses( "A\nb.B\nb.c.C\n" );
+ expectedRecord.setClasses( JAR_CLASS_LIST );
assertEquals( "check record", expectedRecord, record );
}
expectedRecord.setFilename( repository.pathOf( artifact ) );
expectedRecord.setLastModified( artifact.getFile().lastModified() );
expectedRecord.setSize( artifact.getFile().length() );
- expectedRecord.setClasses( "org.apache.maven.repository.record.MyMojo\n" );
+ expectedRecord.setClasses( Collections.singletonList( "org.apache.maven.repository.record.MyMojo" ) );
assertEquals( "check record", expectedRecord, record );
}
import java.io.File;
import java.io.IOException;
+import java.util.Arrays;
+import java.util.List;
/**
* Test the minimal artifact index record.
private static final String TEST_GROUP_ID = "org.apache.maven.repository.record";
+ private static final List JAR_CLASS_LIST = Arrays.asList( new String[]{"A", "b.B", "b.c.C"} );
+
+ private static final List JAR_FILE_LIST =
+ Arrays.asList( new String[]{"META-INF/MANIFEST.MF", "A.class", "b/B.class", "b/c/C.class"} );
+
protected void setUp()
throws Exception
{
expectedRecord.setFilename( repository.pathOf( artifact ) );
expectedRecord.setLastModified( artifact.getFile().lastModified() );
expectedRecord.setSize( artifact.getFile().length() );
- expectedRecord.setClasses( "A\nb.B\nb.c.C\n" );
+ expectedRecord.setClasses( JAR_CLASS_LIST );
expectedRecord.setArtifactId( "test-jar" );
expectedRecord.setGroupId( TEST_GROUP_ID );
expectedRecord.setVersion( "1.0" );
- expectedRecord.setFiles( "META-INF/MANIFEST.MF\nA.class\nb/B.class\nb/c/C.class\n" );
+ expectedRecord.setFiles( JAR_FILE_LIST );
expectedRecord.setSha1Checksum( "c66f18bf192cb613fc2febb4da541a34133eedc2" );
expectedRecord.setType( "jar" );
expectedRecord.setRepository( "test" );
expectedRecord.setFilename( repository.pathOf( artifact ) );
expectedRecord.setLastModified( artifact.getFile().lastModified() );
expectedRecord.setSize( artifact.getFile().length() );
- expectedRecord.setClasses( "A\nb.B\nb.c.C\n" );
+ expectedRecord.setClasses( JAR_CLASS_LIST );
expectedRecord.setArtifactId( "test-jar-and-pom" );
expectedRecord.setGroupId( TEST_GROUP_ID );
expectedRecord.setVersion( "1.0" );
- expectedRecord.setFiles( "META-INF/MANIFEST.MF\nA.class\nb/B.class\nb/c/C.class\n" );
+ expectedRecord.setFiles( JAR_FILE_LIST );
expectedRecord.setSha1Checksum( "c66f18bf192cb613fc2febb4da541a34133eedc2" );
expectedRecord.setType( "jar" );
expectedRecord.setRepository( "test" );
expectedRecord.setFilename( repository.pathOf( artifact ) );
expectedRecord.setLastModified( artifact.getFile().lastModified() );
expectedRecord.setSize( artifact.getFile().length() );
- expectedRecord.setClasses( "A\nb.B\nb.c.C\n" );
+ expectedRecord.setClasses( JAR_CLASS_LIST );
expectedRecord.setArtifactId( "test-child-pom" );
expectedRecord.setGroupId( TEST_GROUP_ID );
expectedRecord.setVersion( "1.0" );
- expectedRecord.setFiles( "META-INF/MANIFEST.MF\nA.class\nb/B.class\nb/c/C.class\n" );
+ expectedRecord.setFiles( JAR_FILE_LIST );
expectedRecord.setSha1Checksum( "c66f18bf192cb613fc2febb4da541a34133eedc2" );
expectedRecord.setType( "jar" );
expectedRecord.setRepository( "test" );
expectedRecord.setSha1Checksum( "382c1ebfb5d0c7d6061c2f8569fb53f8fc00fec2" );
expectedRecord.setType( "maven-plugin" );
expectedRecord.setRepository( "test" );
- expectedRecord.setClasses( "org.apache.maven.repository.record.MyMojo\n" );
- expectedRecord.setFiles( "META-INF/MANIFEST.MF\n" + "META-INF/maven/plugin.xml\n" +
- "org/apache/maven/repository/record/MyMojo.class\n" +
- "META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.xml\n" +
- "META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.properties\n" );
+ expectedRecord.setClasses( Arrays.asList( new String[]{"org.apache.maven.repository.record.MyMojo"} ) );
+ expectedRecord.setFiles( Arrays.asList( new String[]{"META-INF/MANIFEST.MF", "META-INF/maven/plugin.xml",
+ "org/apache/maven/repository/record/MyMojo.class",
+ "META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.xml",
+ "META-INF/maven/org.apache.maven.repository.record/test-plugin/pom.properties"} ) );
expectedRecord.setPackaging( "maven-plugin" );
expectedRecord.setProjectName( "Maven Mojo Archetype" );
expectedRecord.setPluginPrefix( "test" );
expectedRecord.setSha1Checksum( "5ebabafdbcd6684ae434c06e22c32844df284b05" );
expectedRecord.setType( "maven-archetype" );
expectedRecord.setRepository( "test" );
- expectedRecord.setFiles( "META-INF/MANIFEST.MF\n" + "archetype-resources/pom.xml\n" +
- "archetype-resources/src/main/java/App.java\n" + "archetype-resources/src/test/java/AppTest.java\n" +
- "META-INF/maven/archetype.xml\n" +
- "META-INF/maven/org.apache.maven.repository.record/test-archetype/pom.xml\n" +
- "META-INF/maven/org.apache.maven.repository.record/test-archetype/pom.properties\n" );
+ expectedRecord.setFiles( Arrays.asList( new String[]{"META-INF/MANIFEST.MF", "archetype-resources/pom.xml",
+ "archetype-resources/src/main/java/App.java", "archetype-resources/src/test/java/AppTest.java",
+ "META-INF/maven/archetype.xml", "META-INF/maven/org.apache.maven.repository.record/test-archetype/pom.xml",
+ "META-INF/maven/org.apache.maven.repository.record/test-archetype/pom.properties"} ) );
expectedRecord.setPackaging( "jar" );
expectedRecord.setProjectName( "Archetype - test-archetype" );