mirror of https://github.com/apache/maven.git
add an overview page, fix formatting error
git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@169790 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
88b6dea031
commit
0ff8c16056
maven-plugin-tools/maven-plugin-tools-api/src/main/java/org/apache/maven/tools/plugin/generator
|
@ -29,7 +29,6 @@ import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @todo add example usage tag that can be shown in the doco
|
* @todo add example usage tag that can be shown in the doco
|
||||||
|
@ -40,7 +39,7 @@ public class PluginXdocGenerator
|
||||||
public void execute( File destinationDirectory, PluginDescriptor pluginDescriptor )
|
public void execute( File destinationDirectory, PluginDescriptor pluginDescriptor )
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
// TODO: write an overview page
|
writeOverview( destinationDirectory, pluginDescriptor );
|
||||||
|
|
||||||
for ( Iterator it = pluginDescriptor.getMojos().iterator(); it.hasNext(); )
|
for ( Iterator it = pluginDescriptor.getMojos().iterator(); it.hasNext(); )
|
||||||
{
|
{
|
||||||
|
@ -52,14 +51,12 @@ public class PluginXdocGenerator
|
||||||
protected void processMojoDescriptor( MojoDescriptor mojoDescriptor, File destinationDirectory )
|
protected void processMojoDescriptor( MojoDescriptor mojoDescriptor, File destinationDirectory )
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
String id = mojoDescriptor.getGoal();
|
|
||||||
|
|
||||||
FileWriter writer = null;
|
FileWriter writer = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
writer = new FileWriter( new File( destinationDirectory, id + "-mojo.xml" ) );
|
writer = new FileWriter( new File( destinationDirectory, getMojoFilename( mojoDescriptor, "xml" ) ) );
|
||||||
|
|
||||||
writeBody( writer, id, mojoDescriptor );
|
writeBody( writer, mojoDescriptor );
|
||||||
|
|
||||||
writer.flush();
|
writer.flush();
|
||||||
}
|
}
|
||||||
|
@ -69,7 +66,165 @@ public class PluginXdocGenerator
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void writeBody( FileWriter writer, String id, MojoDescriptor mojoDescriptor )
|
private String getMojoFilename( MojoDescriptor mojo, String ext )
|
||||||
|
{
|
||||||
|
return mojo.getGoal() + "-mojo." + ext;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void writeOverview( File destinationDirectory, PluginDescriptor pluginDescriptor )
|
||||||
|
throws IOException
|
||||||
|
{
|
||||||
|
FileWriter writer = null;
|
||||||
|
try
|
||||||
|
{
|
||||||
|
writer = new FileWriter( new File( destinationDirectory, "index.xml" ) );
|
||||||
|
|
||||||
|
writeOverview( writer, pluginDescriptor );
|
||||||
|
|
||||||
|
writer.flush();
|
||||||
|
}
|
||||||
|
finally
|
||||||
|
{
|
||||||
|
IOUtil.close( writer );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void writeOverview( FileWriter writer, PluginDescriptor pluginDescriptor )
|
||||||
|
{
|
||||||
|
XMLWriter w = new PrettyPrintXMLWriter( writer );
|
||||||
|
|
||||||
|
w.startElement( "document" );
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
w.startElement( "properties" );
|
||||||
|
|
||||||
|
w.startElement( "title" );
|
||||||
|
|
||||||
|
// TODO: need a friendly name for a plugin
|
||||||
|
w.writeText( pluginDescriptor.getArtifactId() + " - Overview" );
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
w.startElement( "body" );
|
||||||
|
|
||||||
|
w.startElement( "section" );
|
||||||
|
|
||||||
|
// TODO: need a friendly name for a plugin
|
||||||
|
w.addAttribute( "name", pluginDescriptor.getArtifactId() );
|
||||||
|
|
||||||
|
// TODO: description of plugin, examples?
|
||||||
|
|
||||||
|
w.startElement( "p" );
|
||||||
|
|
||||||
|
w.writeText( "Goals available: " );
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
writeGoalTable( pluginDescriptor, w );
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void writeGoalTable( PluginDescriptor pluginDescriptor, XMLWriter w )
|
||||||
|
{
|
||||||
|
w.startElement( "table" );
|
||||||
|
|
||||||
|
w.startElement( "tr" );
|
||||||
|
|
||||||
|
w.startElement( "th" );
|
||||||
|
|
||||||
|
w.writeText( "Goal" );
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.startElement( "th" );
|
||||||
|
|
||||||
|
w.writeText( "Description" );
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
List mojos = pluginDescriptor.getMojos();
|
||||||
|
|
||||||
|
for ( Iterator i = mojos.iterator(); i.hasNext(); )
|
||||||
|
{
|
||||||
|
MojoDescriptor mojo = (MojoDescriptor) i.next();
|
||||||
|
|
||||||
|
w.startElement( "tr" );
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
w.startElement( "td" );
|
||||||
|
|
||||||
|
String paramName = mojo.getFullGoalName();
|
||||||
|
|
||||||
|
w.startElement( "a" );
|
||||||
|
|
||||||
|
w.addAttribute( "href", getMojoFilename( mojo, "html" ) );
|
||||||
|
|
||||||
|
w.startElement( "code" );
|
||||||
|
|
||||||
|
w.writeText( paramName );
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
//
|
||||||
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
w.startElement( "td" );
|
||||||
|
|
||||||
|
if ( StringUtils.isNotEmpty( mojo.getDescription() ) )
|
||||||
|
{
|
||||||
|
w.writeMarkup( mojo.getDescription() );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
w.writeText( "No description." );
|
||||||
|
}
|
||||||
|
|
||||||
|
String deprecationWarning = mojo.getDeprecated();
|
||||||
|
if ( deprecationWarning != null )
|
||||||
|
{
|
||||||
|
w.writeMarkup( "<br/><b>Deprecated:</b> " );
|
||||||
|
w.writeMarkup( deprecationWarning );
|
||||||
|
if ( deprecationWarning.length() == 0 )
|
||||||
|
{
|
||||||
|
w.writeText( "No reason given." );
|
||||||
|
}
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void writeBody( FileWriter writer, MojoDescriptor mojoDescriptor )
|
||||||
{
|
{
|
||||||
XMLWriter w = new PrettyPrintXMLWriter( writer );
|
XMLWriter w = new PrettyPrintXMLWriter( writer );
|
||||||
|
|
||||||
|
@ -94,6 +249,8 @@ public class PluginXdocGenerator
|
||||||
//
|
//
|
||||||
// ----------------------------------------------------------------------
|
// ----------------------------------------------------------------------
|
||||||
|
|
||||||
|
w.startElement( "body" );
|
||||||
|
|
||||||
w.startElement( "section" );
|
w.startElement( "section" );
|
||||||
|
|
||||||
w.addAttribute( "name", mojoDescriptor.getFullGoalName() );
|
w.addAttribute( "name", mojoDescriptor.getFullGoalName() );
|
||||||
|
@ -185,7 +342,12 @@ public class PluginXdocGenerator
|
||||||
|
|
||||||
if ( !parameter.isRequired() )
|
if ( !parameter.isRequired() )
|
||||||
{
|
{
|
||||||
w.writeMarkup( " <i>(Optional)</i>");
|
w.writeMarkup( " <i>(Optional)</i>" );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( parameter.getExpression() != null && parameter.getExpression().startsWith( "${component." ) )
|
||||||
|
{
|
||||||
|
w.writeMarkup( " <i>(Discovered)</i>" );
|
||||||
}
|
}
|
||||||
|
|
||||||
w.endElement();
|
w.endElement();
|
||||||
|
@ -198,7 +360,17 @@ public class PluginXdocGenerator
|
||||||
|
|
||||||
w.startElement( "code" );
|
w.startElement( "code" );
|
||||||
|
|
||||||
w.writeText( parameter.getType() );
|
w.addAttribute( "title", parameter.getType() );
|
||||||
|
|
||||||
|
int index = parameter.getType().lastIndexOf( "." );
|
||||||
|
if ( index >= 0 )
|
||||||
|
{
|
||||||
|
w.writeText( parameter.getType().substring( index + 1 ) );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
w.writeText( parameter.getType() );
|
||||||
|
}
|
||||||
|
|
||||||
w.endElement();
|
w.endElement();
|
||||||
|
|
||||||
|
@ -212,7 +384,8 @@ public class PluginXdocGenerator
|
||||||
|
|
||||||
w.startElement( "code" );
|
w.startElement( "code" );
|
||||||
|
|
||||||
if ( StringUtils.isNotEmpty( parameter.getExpression() ) )
|
if ( StringUtils.isNotEmpty( parameter.getExpression() ) &&
|
||||||
|
!parameter.getExpression().startsWith( "${component." ) )
|
||||||
{
|
{
|
||||||
w.writeText( parameter.getExpression() );
|
w.writeText( parameter.getExpression() );
|
||||||
}
|
}
|
||||||
|
@ -243,7 +416,7 @@ public class PluginXdocGenerator
|
||||||
String deprecationWarning = parameter.getDeprecated();
|
String deprecationWarning = parameter.getDeprecated();
|
||||||
if ( deprecationWarning != null )
|
if ( deprecationWarning != null )
|
||||||
{
|
{
|
||||||
w.writeMarkup( "<br/><b>Deprecated:</b> ");
|
w.writeMarkup( "<br/><b>Deprecated:</b> " );
|
||||||
w.writeMarkup( deprecationWarning );
|
w.writeMarkup( deprecationWarning );
|
||||||
if ( deprecationWarning.length() == 0 )
|
if ( deprecationWarning.length() == 0 )
|
||||||
{
|
{
|
||||||
|
@ -259,5 +432,7 @@ public class PluginXdocGenerator
|
||||||
}
|
}
|
||||||
|
|
||||||
w.endElement();
|
w.endElement();
|
||||||
|
|
||||||
|
w.endElement();
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue