Update to new reporting-api

git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@169079 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Emmanuel Venisse 2005-05-07 13:42:42 +00:00
parent dd5f4fed12
commit 71bb78fb08
3 changed files with 178 additions and 13 deletions

View File

@ -29,13 +29,10 @@ import org.codehaus.plexus.util.StringInputStream;
import org.codehaus.plexus.util.StringUtils; import org.codehaus.plexus.util.StringUtils;
import java.io.File; import java.io.File;
import java.io.FileWriter;
import java.io.InputStream; import java.io.InputStream;
import java.io.IOException; import java.io.IOException;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet;
import java.util.Map; import java.util.Map;
import java.util.Set;
/** /**
* @goal checkstyle * @goal checkstyle

View File

@ -22,11 +22,17 @@ import org.apache.maven.project.MavenProject;
import org.apache.maven.reporting.MavenReport; import org.apache.maven.reporting.MavenReport;
import org.apache.maven.reporting.MavenReportConfiguration; import org.apache.maven.reporting.MavenReportConfiguration;
import org.apache.maven.reporting.MavenReportException; import org.apache.maven.reporting.MavenReportException;
import org.codehaus.doxia.module.xhtml.XhtmlSink;
import org.codehaus.doxia.site.renderer.SiteRenderer;
import org.codehaus.plexus.util.FileUtils;
import org.codehaus.plexus.util.StringInputStream;
import org.codehaus.plexus.util.StringUtils;
import java.io.File; import java.io.File;
import java.io.FileWriter; import java.io.InputStream;
import java.util.HashSet; import java.io.IOException;
import java.util.Set; import java.util.HashMap;
import java.util.Map;
/** /**
* @goal pmd * @goal pmd
@ -39,11 +45,35 @@ public class PmdReportMojo
extends AbstractMojo extends AbstractMojo
{ {
/** /**
* @parameter alias="workingDirectory" expression="${project.build.directory}/site-generated" * @parameter expression="${basedir}"
* @required
*/
private String basedir;
/**
* @parameter expression="${basedir}/src/site"
* @required
*/
private String siteDirectory;
/**
* @parameter expression="${project.build.directory}/site"
* @required * @required
*/ */
private String outputDirectory; private String outputDirectory;
/**
* @parameter alias="flavor"
*/
private String flavour = "maven";
/**
* @parameter expression="${component.org.codehaus.doxia.site.renderer.SiteRenderer}"
* @required
* @readonly
*/
private SiteRenderer siteRenderer;
/** /**
* @parameter expression="${project}" * @parameter expression="${project}"
* @required * @required
@ -66,11 +96,61 @@ public class PmdReportMojo
try try
{ {
report.generate(); XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), siteDirectory,
report.getOutputName() + ".html",
outputDirectory, getSiteDescriptor(), flavour );
report.generate( sink );
siteRenderer.copyResources( siteDirectory, outputDirectory, flavour );
} }
catch ( MavenReportException e ) catch ( Exception e )
{ {
throw new MojoExecutionException( "An error is occurred in the PMD report generation.", e ); throw new MojoExecutionException( "An error is occurred in the PMD report generation.", e );
} }
} }
private String getReportsMenu()
{
StringBuffer buffer = new StringBuffer();
buffer.append( "<menu name=\"Project Documentation\">\n" );
buffer.append( " <item name=\"About " + project.getName() + "\" href=\"/index.html\"/>\n");
buffer.append( " <item name=\"Project reports\" href=\"/maven-reports.html\" collapse=\"true\">\n" );
buffer.append( " <item name=\"PMD report\" href=\"/pmd.html\"/>\n" );
buffer.append( " </item>\n" );
buffer.append( "</menu>\n" );
return buffer.toString();
}
private InputStream getSiteDescriptor()
throws MojoExecutionException
{
File siteDescriptor = new File( siteDirectory, "site.xml" );
if ( !siteDescriptor.exists() )
{
throw new MojoExecutionException( "The site descriptor is not present!" );
}
String siteDescriptorContent = "";
try
{
siteDescriptorContent = FileUtils.fileRead( siteDescriptor );
}
catch( IOException e )
{
throw new MojoExecutionException( "The site descriptor cannot be read!", e );
}
Map props = new HashMap();
props.put( "reports", getReportsMenu() );
siteDescriptorContent = StringUtils.interpolate( siteDescriptorContent, props );
return new StringInputStream( siteDescriptorContent );
}
} }

View File

@ -22,8 +22,17 @@ import org.apache.maven.project.MavenProject;
import org.apache.maven.reporting.MavenReport; import org.apache.maven.reporting.MavenReport;
import org.apache.maven.reporting.MavenReportConfiguration; import org.apache.maven.reporting.MavenReportConfiguration;
import org.apache.maven.reporting.MavenReportException; import org.apache.maven.reporting.MavenReportException;
import org.codehaus.doxia.module.xhtml.XhtmlSink;
import org.codehaus.doxia.site.renderer.SiteRenderer;
import org.codehaus.plexus.util.FileUtils;
import org.codehaus.plexus.util.StringInputStream;
import org.codehaus.plexus.util.StringUtils;
import java.io.File; import java.io.File;
import java.io.InputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
/** /**
* @goal generate * @goal generate
@ -36,11 +45,35 @@ public class ProjectReportsMojo
extends AbstractMojo extends AbstractMojo
{ {
/** /**
* @parameter alias="workingDirectory" expression="${project.build.directory}/site-generated" * @parameter expression="${basedir}"
* @required
*/
private String basedir;
/**
* @parameter expression="${basedir}/src/site"
* @required
*/
private String siteDirectory;
/**
* @parameter expression="${project.build.directory}/site"
* @required * @required
*/ */
private String outputDirectory; private String outputDirectory;
/**
* @parameter alias="flavor"
*/
private String flavour = "maven";
/**
* @parameter expression="${component.org.codehaus.doxia.site.renderer.SiteRenderer}"
* @required
* @readonly
*/
private SiteRenderer siteRenderer;
/** /**
* @parameter expression="${project}" * @parameter expression="${project}"
* @required * @required
@ -67,13 +100,68 @@ public class ProjectReportsMojo
try try
{ {
dependenciesReport.generate(); XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), siteDirectory,
dependenciesReport.getOutputName() + ".html",
outputDirectory, getSiteDescriptor(), flavour );
mailingListsReport.generate(); dependenciesReport.generate( sink );
sink = siteRenderer.createSink( new File( siteDirectory ), siteDirectory,
mailingListsReport.getOutputName() + ".html",
outputDirectory, getSiteDescriptor(), flavour );
mailingListsReport.generate( sink );
siteRenderer.copyResources( siteDirectory, outputDirectory, flavour );
} }
catch ( MavenReportException e ) catch ( Exception e )
{ {
throw new MojoExecutionException( "An error is occurred in the report generation.", e ); throw new MojoExecutionException( "An error is occurred in the report generation.", e );
} }
} }
private String getReportsMenu()
{
StringBuffer buffer = new StringBuffer();
buffer.append( "<menu name=\"Project Documentation\">\n" );
buffer.append( " <item name=\"About " + project.getName() + "\" href=\"/index.html\"/>\n");
buffer.append( " <item name=\"Project reports\" href=\"/maven-reports.html\" collapse=\"true\">\n" );
buffer.append( " <item name=\"Dependencies\" href=\"/dependencies.html\"/>\n" );
buffer.append( " <item name=\"Mailing list\" href=\"/mail-list.html\"/>\n" );
buffer.append( " </item>\n" );
buffer.append( "</menu>\n" );
return buffer.toString();
}
private InputStream getSiteDescriptor()
throws MojoExecutionException
{
File siteDescriptor = new File( siteDirectory, "site.xml" );
if ( !siteDescriptor.exists() )
{
throw new MojoExecutionException( "The site descriptor is not present!" );
}
String siteDescriptorContent = "";
try
{
siteDescriptorContent = FileUtils.fileRead( siteDescriptor );
}
catch( IOException e )
{
throw new MojoExecutionException( "The site descriptor cannot be read!", e );
}
Map props = new HashMap();
props.put( "reports", getReportsMenu() );
siteDescriptorContent = StringUtils.interpolate( siteDescriptorContent, props );
return new StringInputStream( siteDescriptorContent );
}
} }