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

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

/*
 * #%L
 * I18n :: Maven Plugin
 * 
 * $Id: ParserJavaMojo.java 1971 2012-08-29 19:38:52Z tchemit $
 * $HeadURL: http://svn.nuiton.org/svn/i18n/tags/i18n-2.5.2/i18n-maven-plugin/src/main/java/org/nuiton/i18n/plugin/parser/impl/ParserJavaMojo.java $
 * %%
 * Copyright (C) 2007 - 2010 CodeLutin, Tony Chemit
 * %%
 * 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.apache.maven.plugin.logging.Log;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.nuiton.i18n.plugin.parser.AbstractFileParser;
import org.nuiton.i18n.plugin.parser.AbstractI18nParserMojo;
import org.nuiton.i18n.plugin.parser.FileParser;
import org.nuiton.i18n.plugin.parser.I18nSourceEntry;
import org.nuiton.i18n.plugin.parser.ParserException;
import org.nuiton.i18n.plugin.parser.SourceEntry;
import org.nuiton.io.FileUpdater;
import org.nuiton.io.FileUpdaterHelper;
import org.nuiton.io.SortedProperties;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.LineNumberReader;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * To parse java files to detect new i18n keys.
 * 

* Note: this goal must always be invoked before the {@code process-resources} * phase, otherwise all files will be considered as uptodate. * * @author jruchaud * @author tchemit */ @Mojo(name = "parserJava", defaultPhase = LifecyclePhase.GENERATE_RESOURCES) public class ParserJavaMojo extends AbstractI18nParserMojo { public static final String DEFAULT_INCLUDES = "**/*.java"; /** Root directory of the default entry. */ @Parameter(property = "i18n.defaultBasedir", defaultValue = "${basedir}/src/main/java") protected File defaultBasedir; /** * Default included files to process (ant-like expression). *

* Note: default value is **\/*.java */ @Parameter(property = "i18n.defaultIncludes", defaultValue = DEFAULT_INCLUDES, required = true) protected String defaultIncludes; /** * Defines the file name of the getter where to put detected i18n keys * while getter phase. * * @since 2.0 */ @Parameter(property = "i18n.outputGetter", defaultValue = "java.getter") protected String outputGetter; @Override public String[] getDefaultIncludes() { return new String[]{defaultIncludes}; } @Override public String[] getDefaultExcludes() { return I18nSourceEntry.EMPTY_STRING_ARRAY; } @Override public File getDefaultBasedir() { return defaultBasedir; } @Override public FileUpdater newFileUpdater(SourceEntry entry) { return FileUpdaterHelper.newJavaFileUpdater(entry.getBasedir(), cp); } @Override protected String getOutGetter() { return outputGetter; } @Override public FileParser newFileParser(Pattern acceptPattern) { return new JavaFileParser(getLog(), encoding, oldParser, acceptPattern, isShowTouchedFiles() ); } protected static class JavaFileParser extends AbstractFileParser { /** * Pattern used to detect i18n keys. * * @since 2.3 */ protected final Pattern i18nPattern = Pattern.compile("(?:^_\\(\\s*\\\"|[^l]_\\(\\s*\\\"|l_\\([^,]+\\s*,\\s*\\\")(.*?)\""); public JavaFileParser(Log log, String encoding, SortedProperties oldParser, Pattern acceptKeyPattern, boolean showTouchedFiles) { super(log, encoding, oldParser, acceptKeyPattern, showTouchedFiles); } public Pattern getI18nPattern() { return i18nPattern; } @Override public void parseFile(File file) throws IOException { String line = null; LineNumberReader lnr = new LineNumberReader(new InputStreamReader( new FileInputStream(file), getEncoding())); try { while ((line = lnr.readLine()) != null) { parseLine(file, line); } } catch (Exception e) { if (line != null) { getLog().error( "could not parse line (" + lnr.getLineNumber() + ") '" + line + "' of file " + file); } throw new ParserException(e); } finally { lnr.close(); } } @Override public void parseLine(File file, String line) throws IOException { Matcher matcher = i18nPattern.matcher(line); while (matcher.find()) { String key = matcher.group(1); if (getLog().isDebugEnabled()) { getLog().debug(file.getName() + " detected key = " + key); } // // one key found in file, so file is marked as touched // setTouched(true); // register key registerKey(key); } } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy