org.jboss.maven.plugins.jdocbook.PackageMojo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of maven-jdocbook-plugin
Show all versions of maven-jdocbook-plugin
This plugin adds support for DocBook handling to Maven.
/*
* jDocBook, processing of DocBook sources
*
* Copyright (c) 2010, Red Hat Inc. or third-party contributors as
* indicated by the @author tags or express copyright attribution
* statements applied by the authors. All third-party contributions are
* distributed under license by Red Hat Inc.
*
* This copyrighted material is made available to anyone wishing to use, modify,
* copy, or redistribute it subject to the terms and conditions of the GNU
* Lesser General Public License, as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
* for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution; if not, write to:
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA
*/
package org.jboss.maven.plugins.jdocbook;
import java.io.File;
import java.io.IOException;
import org.codehaus.plexus.archiver.ArchiverException;
import org.codehaus.plexus.archiver.jar.JarArchiver;
import org.jboss.jdocbook.render.RenderingException;
import org.jboss.jdocbook.xslt.XSLTException;
/**
* This mojo's responsibility within the plugin/packaging is to bundle the
* individual formats into deployable formats. The desicion Note that some formats (PDF, e.g.) are
* already deployable.
*
* After bundling, each bundle is then attached to the project
*
* @goal bundle
* @phase package
* @requiresDependencyResolution
*
* @author Steve Ebersole
*/
@SuppressWarnings({ "UnusedDeclaration" })
public class PackageMojo extends AbstractDocBookMojo {
/**
* {@inheritDoc}
*/
@Override
protected void process() throws RenderingException, XSLTException {
File projectArtifactFile = new File( project.getBuild().getOutputDirectory(), project.getBuild().getFinalName() + ".war" );
JarArchiver warBuilder = new JarArchiver();
warBuilder.setDestFile( projectArtifactFile );
final Matcher formatMatcher = new Matcher( getRequestedFormat() );
try {
for ( PublishingSource source : resolvePublishingSources() ) {
for ( Format format : getFormatOptionsList() ) {
if ( formatMatcher.matches( format.getName() ) ) {
warBuilder.addDirectory(
new File( source.resolvePublishingBaseDirectory(), format.getName() ),
format.getName() + "/"
);
}
}
}
warBuilder.createArchive();
}
catch ( IOException e ) {
throw new RenderingException( "Unable to create archive [" + projectArtifactFile.getAbsolutePath() + "]", e );
}
catch ( ArchiverException e ) {
throw new RenderingException( "Unable to populate archive [" + projectArtifactFile.getAbsolutePath() + "]", e );
}
project.getArtifact().setFile( projectArtifactFile );
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy