use resources directory instead

git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@178561 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Brett Leslie Porter 2005-05-26 01:03:08 +00:00
parent dc01cea9f8
commit d408365aea
1 changed files with 47 additions and 27 deletions

View File

@ -25,25 +25,24 @@ import org.apache.maven.reporting.MavenReportConfiguration;
import org.codehaus.doxia.module.xhtml.XhtmlSink; import org.codehaus.doxia.module.xhtml.XhtmlSink;
import org.codehaus.doxia.site.renderer.SiteRenderer; import org.codehaus.doxia.site.renderer.SiteRenderer;
import org.codehaus.plexus.util.FileUtils; import org.codehaus.plexus.util.FileUtils;
import org.codehaus.plexus.util.IOUtil;
import org.codehaus.plexus.util.StringInputStream; import org.codehaus.plexus.util.StringInputStream;
import org.codehaus.plexus.util.StringUtils; import org.codehaus.plexus.util.StringUtils;
import org.codehaus.plexus.util.IOUtil;
import java.util.ArrayList;
import java.io.File; import java.io.File;
import java.io.InputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
/** /**
* @goal site
* @description Doxia plugin
*
* @author <a href="mailto:evenisse@apache.org">Emmanuel Venisse</a> * @author <a href="mailto:evenisse@apache.org">Emmanuel Venisse</a>
* @version $Id$ * @version $Id$
* @goal site
* @description Doxia plugin
*/ */
public class DoxiaMojo public class DoxiaMojo
extends AbstractMojo extends AbstractMojo
@ -72,6 +71,12 @@ public class DoxiaMojo
*/ */
private String outputDirectory; private String outputDirectory;
/**
* @parameter expression="${basedir}/src/site/resources"
* @required
*/
private File resourcesDirectory;
/** /**
* @parameter alias="flavor" * @parameter alias="flavor"
*/ */
@ -82,7 +87,7 @@ public class DoxiaMojo
* @required * @required
* @readonly * @readonly
*/ */
private SiteRenderer siteRenderer; private SiteRenderer siteRenderer;
/** /**
* @parameter expression="${project}" * @parameter expression="${project}"
@ -113,6 +118,7 @@ public class DoxiaMojo
private List remoteRepositories; private List remoteRepositories;
private List projectInfos = new ArrayList(); private List projectInfos = new ArrayList();
private List projectReports = new ArrayList(); private List projectReports = new ArrayList();
public void execute() public void execute()
@ -141,9 +147,9 @@ public class DoxiaMojo
report.setConfiguration( config ); report.setConfiguration( config );
XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), siteDirectory, XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ),
report.getOutputName() + ".html", report.getOutputName() + ".html", outputDirectory,
outputDirectory, getSiteDescriptor(), flavour ); getSiteDescriptor(), flavour );
report.generate( sink ); report.generate( sink );
} }
@ -174,8 +180,22 @@ public class DoxiaMojo
} }
} }
File cssDirectory = new File( siteDirectory, "css" );
File imagesDirectory = new File( siteDirectory, "images" );
// special case for backwards compatibility
if ( cssDirectory.exists() || imagesDirectory.exists() )
{
getLog().warn( "DEPRECATED: the css and images directories are deprecated, please use resources" );
FileUtils.copyDirectory( cssDirectory, new File( outputDirectory, "css" ) );
FileUtils.copyDirectory( imagesDirectory, new File( outputDirectory, "images" ) );
}
//Generate static site //Generate static site
siteRenderer.render( siteDirectory, generatedSiteDirectory, outputDirectory, flavour, getSiteDescriptor() ); siteRenderer.render( siteDirectory, generatedSiteDirectory, outputDirectory, flavour, getSiteDescriptor(),
resourcesDirectory );
} }
catch ( Exception e ) catch ( Exception e )
{ {
@ -211,7 +231,7 @@ public class DoxiaMojo
{ {
StringBuffer buffer = new StringBuffer(); StringBuffer buffer = new StringBuffer();
buffer.append( "<menu name=\"Project Documentation\">\n" ); buffer.append( "<menu name=\"Project Documentation\">\n" );
buffer.append( " <item name=\"About " + project.getName() + "\" href=\"/index.html\"/>\n"); buffer.append( " <item name=\"About " + project.getName() + "\" href=\"/index.html\"/>\n" );
if ( projectInfos.size() > 0 ) if ( projectInfos.size() > 0 )
{ {
@ -221,8 +241,9 @@ public class DoxiaMojo
for ( Iterator i = projectInfos.iterator(); i.hasNext(); ) for ( Iterator i = projectInfos.iterator(); i.hasNext(); )
{ {
MavenReport report = (MavenReport) i.next(); MavenReport report = (MavenReport) i.next();
buffer.append( " <item name=\"" + report.getName() + "\" href=\"/" + buffer.append(
report.getOutputName() + ".html\"/>\n" ); " <item name=\"" + report.getName() + "\" href=\"/" + report.getOutputName() +
".html\"/>\n" );
} }
buffer.append( " </item>\n" ); buffer.append( " </item>\n" );
@ -236,8 +257,9 @@ public class DoxiaMojo
for ( Iterator i = projectReports.iterator(); i.hasNext(); ) for ( Iterator i = projectReports.iterator(); i.hasNext(); )
{ {
MavenReport report = (MavenReport) i.next(); MavenReport report = (MavenReport) i.next();
buffer.append( " <item name=\"" + report.getName() + "\" href=\"/" + buffer.append(
report.getOutputName() + ".html\"/>\n" ); " <item name=\"" + report.getName() + "\" href=\"/" + report.getOutputName() +
".html\"/>\n" );
} }
buffer.append( " </item>\n" ); buffer.append( " </item>\n" );
@ -266,7 +288,7 @@ public class DoxiaMojo
siteDescriptorContent = IOUtil.toString( getClass().getResourceAsStream( "/default-site.xml" ) ); siteDescriptorContent = IOUtil.toString( getClass().getResourceAsStream( "/default-site.xml" ) );
} }
} }
catch( IOException e ) catch ( IOException e )
{ {
throw new MojoExecutionException( "The site descriptor cannot be read!", e ); throw new MojoExecutionException( "The site descriptor cannot be read!", e );
} }
@ -306,9 +328,8 @@ public class DoxiaMojo
private void generateProjectInfoPage( InputStream siteDescriptor ) private void generateProjectInfoPage( InputStream siteDescriptor )
throws Exception throws Exception
{ {
XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), siteDirectory, XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), "project-info.html", outputDirectory,
"project-info.html", siteDescriptor, flavour );
outputDirectory, siteDescriptor, flavour );
String title = "General Project Information"; String title = "General Project Information";
@ -326,7 +347,7 @@ public class DoxiaMojo
sink.paragraph(); sink.paragraph();
sink.text( "This document provides an overview of the various documents and links that are part " + sink.text( "This document provides an overview of the various documents and links that are part " +
"of this project's general information. All of this content is automatically generated by "); "of this project's general information. All of this content is automatically generated by " );
sink.link( "http://maven.apache.org" ); sink.link( "http://maven.apache.org" );
sink.text( "Maven" ); sink.text( "Maven" );
sink.link_(); sink.link_();
@ -379,12 +400,11 @@ public class DoxiaMojo
sink.close(); sink.close();
} }
private void generateProjectReportsPage( InputStream siteDescriptor) private void generateProjectReportsPage( InputStream siteDescriptor )
throws Exception throws Exception
{ {
XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), siteDirectory, XhtmlSink sink = siteRenderer.createSink( new File( siteDirectory ), "maven-reports.html", outputDirectory,
"maven-reports.html", siteDescriptor, flavour );
outputDirectory, siteDescriptor, flavour );
String title = "Maven Generated Reports"; String title = "Maven Generated Reports";