mirror of https://github.com/apache/maven.git
Lazy loading of model input stream.
git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@764661 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6db2a155ec
commit
58886bc0e8
|
@ -111,7 +111,6 @@ public class PomClassicDomainModel implements DomainModel
|
|||
}
|
||||
|
||||
initializeProperties( model );
|
||||
|
||||
}
|
||||
|
||||
public PomClassicDomainModel(Model model) throws IOException {
|
||||
|
@ -122,23 +121,9 @@ public class PomClassicDomainModel implements DomainModel
|
|||
this.model = model;
|
||||
this.isMostSpecialized = b;
|
||||
|
||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||
Writer out = null;
|
||||
MavenXpp3Writer writer = new MavenXpp3Writer();
|
||||
try
|
||||
{
|
||||
out = WriterFactory.newXmlWriter( baos );
|
||||
writer.write( out, model );
|
||||
}
|
||||
finally
|
||||
{
|
||||
if ( out != null )
|
||||
{
|
||||
out.close();
|
||||
}
|
||||
}
|
||||
|
||||
initializeProperties( model );
|
||||
inputBytes = baos.toByteArray();
|
||||
|
||||
}
|
||||
|
||||
public File getParentFile()
|
||||
|
@ -213,28 +198,63 @@ public class PomClassicDomainModel implements DomainModel
|
|||
*
|
||||
* @return XML model as string
|
||||
*/
|
||||
public String asString()
|
||||
public String asString() throws IOException
|
||||
{
|
||||
if(inputBytes == null)
|
||||
{
|
||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||
Writer out = null;
|
||||
MavenXpp3Writer writer = new MavenXpp3Writer();
|
||||
try
|
||||
{
|
||||
return IOUtil.toString( ReaderFactory.newXmlReader( new ByteArrayInputStream( inputBytes ) ) );
|
||||
out = WriterFactory.newXmlWriter( baos );
|
||||
writer.write( out, model );
|
||||
}
|
||||
catch ( IOException ioe )
|
||||
finally
|
||||
{
|
||||
// should not occur: everything is in-memory
|
||||
return "";
|
||||
if ( out != null )
|
||||
{
|
||||
out.close();
|
||||
}
|
||||
}
|
||||
inputBytes = baos.toByteArray();
|
||||
}
|
||||
|
||||
return IOUtil.toString( ReaderFactory.newXmlReader( new ByteArrayInputStream( inputBytes ) ) );
|
||||
}
|
||||
|
||||
/**
|
||||
* @see org.apache.maven.shared.model.InputStreamDomainModel#getInputStream()
|
||||
*/
|
||||
public InputStream getInputStream()
|
||||
public InputStream getInputStream() throws IOException
|
||||
{
|
||||
if(inputBytes != null)
|
||||
{
|
||||
byte[] copy = new byte[inputBytes.length];
|
||||
System.arraycopy( inputBytes, 0, copy, 0, inputBytes.length );
|
||||
return new ByteArrayInputStream( copy );
|
||||
}
|
||||
else
|
||||
{
|
||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||
Writer out = null;
|
||||
MavenXpp3Writer writer = new MavenXpp3Writer();
|
||||
try
|
||||
{
|
||||
out = WriterFactory.newXmlWriter( baos );
|
||||
writer.write( out, model );
|
||||
}
|
||||
finally
|
||||
{
|
||||
if ( out != null )
|
||||
{
|
||||
out.close();
|
||||
}
|
||||
}
|
||||
inputBytes = baos.toByteArray();
|
||||
return new ByteArrayInputStream(inputBytes);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @return file of pom. May be null.
|
||||
|
|
Loading…
Reference in New Issue