All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.nuiton.i18n.plugin.parser.impl.ParserJspMojo Maven / Gradle / Ivy

/*
 * #%L
 * I18n :: Maven Plugin
 * 
 * $Id: ParserJspMojo.java 1808 2010-11-16 08:59:10Z tchemit $
 * $HeadURL: http://svn.nuiton.org/svn/i18n/tags/i18n-2.0.1/maven-i18n-plugin/src/main/java/org/nuiton/i18n/plugin/parser/impl/ParserJspMojo.java $
 * %%
 * Copyright (C) 2007 - 2010 CodeLutin
 * %%
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as 
 * published by the Free Software Foundation, either version 3 of the 
 * License, or (at your option) any later version.
 * 
 * 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 General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public 
 * License along with this program.  If not, see
 * .
 * #L%
 */

package org.nuiton.i18n.plugin.parser.impl;

import org.nuiton.i18n.plugin.parser.I18nSourceEntry;
import org.nuiton.i18n.plugin.parser.SourceEntry;
import org.nuiton.io.FileUpdater;
import org.nuiton.io.MirroredFileUpdater;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.xpath.XPath;
import java.io.File;
import java.io.IOException;

/**
 * Find i18n keys from jsp files.
 * 

* Note: this goal must always be invoked before the {@code process-resources} * phase, otherwise all files will be considered as uptodate. * * @author tchemit * @goal parserJsp * @phase generate-resources * @since 2.0 */ public class ParserJspMojo extends AbstractParserXmlMojo { /** * Root directory of the default entry. * * @parameter expression="${i18n.defaultBasedir}" default-value="${basedir}/src/main/webapp" * @required */ protected File defaultBasedir; /** * Default included files to process (ant-like expression). * * @parameter expression="${i18n.defaultIncludes}" default-value="**\/**.jsp" */ protected String defaultIncludes; /** * Defines the core rules file used to detect i18n keys in jsp files. *

* Note : If you do not want to use it, set it to empty and fill the * {@link #userRulesFiles} parameter. * * @parameter expression="${i18n.coreRuleFile}" * @since 2.0 */ protected String coreRuleFile; /** * Defines the file name of the getter where to put detected i18n keys * while getter phase. * * @parameter expression="${i18n.outputGetter}" default-value="jsp.getter" * @since 2.0 */ protected String outputGetter; /** * Where to generated temporary processed files. * * @parameter expression="${i18n.workdir}" default-value="${basedir}/target/i18n-workdir" * @since 2.0 */ protected File workdir; @Override public String[] getDefaultIncludes() { return new String[]{defaultIncludes}; } @Override public String[] getDefaultExcludes() { return I18nSourceEntry.EMPTY_STRING_ARRAY; } @Override public File getDefaultBasedir() { return defaultBasedir; } MirroredFileUpdater entryUpdater; @Override protected boolean onEnterEntry(I18nSourceEntry entry) { boolean b = super.onEnterEntry(entry); if (!b) { // no skipped entry // keep the file updater entryUpdater = (MirroredFileUpdater) entry.getUpdater(); } return b; } @Override public FileUpdater newFileUpdater(SourceEntry entry) { return new MirroredFileUpdater("", "", entry.getBasedir(), workdir) { @Override public File getMirrorFile(File f) { String file = f.getAbsolutePath().substring(prefixSourceDirecotory); return new File(destinationDirectory + File.separator + file + "~"); } }; } @Override protected String getOutGetter() { return outputGetter; } @Override protected String getCoreRuleFile() { return coreRuleFile; } protected XmlFileParser newXmlFileParser(final XPath xpath, final DocumentBuilder builder) { return new XmlFileParser(getLog(), getEncoding(), oldParser, showTouchedFiles, rules, xpath, builder, namespaces, isVerbose()) { @Override public File prepareFile(File file) throws IOException { // clean the jsp to make it xml File result = entryUpdater.getMirrorFile(file); createDirectoryIfNecessary(result.getParentFile()); JspFileProcessor processor = new JspFileProcessor(); processor.process(file, result, getEncoding()); return result; } @Override public String extract(String i18nString) { String s = null; if (!i18nString.trim().isEmpty()) { s = i18nString.trim(); } if (getLog().isDebugEnabled()) { getLog().debug(i18nString + " = " + s); } return s; } }; } @Override @Deprecated protected String getKeyModifierStart() { return "=\\s*[\"\']"; } @Override @Deprecated protected String getKeyModifierEnd() { return "[\"\']"; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy