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

org.nuiton.jaxx.plugin.GenerateHelpIdsMojo Maven / Gradle / Ivy

/*
 * #%L
 * JAXX :: Maven plugin
 * %%
 * Copyright (C) 2008 - 2020 Code Lutin, Ultreia.io
 * %%
 * 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.jaxx.plugin;

import com.google.common.base.Charsets;
import com.google.common.io.Closeables;
import com.google.common.io.Files;
import org.apache.commons.lang3.StringUtils;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.nuiton.jaxx.compiler.decorators.HelpRootCompiledObjectDecorator;
import org.nuiton.io.SortedProperties;

import java.io.File;
import java.io.IOException;
import java.io.Reader;
import java.io.Writer;
import java.util.HashSet;
import java.util.Locale;
import java.util.Set;

/**
 * Generate the help ids files from the previous jaxx generation.
 *
 * Created: 22 déc. 2009
 *
 * @author Tony Chemit - [email protected]
 * @since 2.0.0
 */
@Mojo(name = "generate-help-ids",
        defaultPhase = LifecyclePhase.PROCESS_SOURCES, requiresProject = true)
public class GenerateHelpIdsMojo extends AbstractGenerateHelpMojo {

    public static final String INPUT_FILENAME_FULL_FORMAT = "%s-%s_%s.properties";

    public static final String INPUT_FILENAME_FORMAT = "%s-%s.properties";

    /**
     * Flag to merge ids into input directory.
     *
     * @since 2.5.12
     */
    @Parameter(property = "jaxx.mergeIdsToInput",
            defaultValue = "false",
            required = true)
    protected boolean mergeIdsToInput;

    /**
     * Flag to remove obsolete ids into input files.
     *
     * Important Note: Be sure to use this after a clean, or
     * using with {@code jaxx.force} property to get all ids of any jaxx files
     * detected, otherwise you could loose some data. USE WITH CAUTION.
     *
     * Note: Only used when {@code mergeIdsToInput} parameter
     * is on.
     *
     * @since 2.5.12
     */
    @Parameter(property = "jaxx.strictMode",
            defaultValue = "false",
            required = true)
    protected boolean strictMode;

    /**
     * Directory where to merge (create) input files.
     *
     * Note: Only used when {@code mergeIdsToInput} parameter
     * is on.
     *
     * @since 2.5.12
     */
    @Parameter(property = "jaxx.inputHelpDirectory",
            defaultValue = "src/main/help",
            required = true)
    protected File inputHelpDirectory;

    /**
     * Prefix of input files.
     *
     * Note: {@code -locale.properties} will be added to each
     * generated file (example: {@code helpMapping-fr_FR.properties}).
     *
     * Note: Only used when {@code mergeIdsToInput} parameter
     * is on.
     *
     * @since 2.5.12
     */
    @Parameter(property = "jaxx.inputHelpFilenamePrefix",
            defaultValue = "helpMapping",
            required = true)
    protected String inputHelpFilenamePrefix;

    /** help ids to react. */
    protected Set helpIds;

    @Override
    public void init() throws Exception {
        if (!generateHelp) {

            return;
        }

        super.init();

        // check there is some bundle
        if (getHelpIdsFilename() == null) {
            throw new MojoFailureException(
                    "you must set the 'helpIdStore' property.");
        }
        if (getMergeHelpIdsFilename() == null) {
            throw new MojoFailureException(
                    "you must set the 'helpIdStoreAll' property.");
        }

        helpIds = HelpRootCompiledObjectDecorator.getHelpIds();

        // always clean helpIdsStore before all
        cleanHelpIdsStore();

        if (mergeIdsToInput) {
            createDirectoryIfNecessary(inputHelpDirectory);
        }

    }

    @Override
    protected boolean checkSkip() {
        boolean b = super.checkSkip();
        if (b) {

            if (strictMode) {

                // always launch goal
                getLog().info("Strict mode is on, will use all detected ids.");

            } else if (helpIds.isEmpty()) {

                // no ids detected in this compilation round
                getLog().info("No help ids to treate, will skip goal.");
                b = false;
            }
        }
        return b;
    }

    @Override
    protected void preDoAction() throws IOException {
        // store current jaxx session detected help ids

        File idsStore = getHelpIdsStoreFile();
        getLog().info("Store detected help ids to " + idsStore);

        storeHelpIds(idsStore, helpIds);

        // store merged help ids (to make possible a force on help generation)


        File idsStoreAll = getMergeHelpIdsStoreFile();
        getLog().info("Merge help ids to " + idsStoreAll);

        if (idsStoreAll.exists()) {
            Set allIds = loadHelpIds(idsStoreAll);
            helpIds.addAll(allIds);
        }

        storeHelpIds(idsStoreAll, helpIds);
    }

    @Override
    protected void doActionForLocale(Locale locale,
                                     boolean isDefaultLocale,
                                     File source,
                                     String localePath) throws Exception {
        // nothing to do specific to locale

        if (mergeIdsToInput) {

            String filename;

            if (StringUtils.isNotEmpty(locale.getCountry())) {
                filename = String.format(
                        INPUT_FILENAME_FULL_FORMAT,
                        inputHelpFilenamePrefix,
                        locale.getLanguage(),
                        locale.getCountry());
            } else {
                filename = String.format(
                        INPUT_FILENAME_FORMAT,
                        inputHelpFilenamePrefix,
                        locale.getLanguage());
            }

            File inputFile = new File(inputHelpDirectory, filename);

            getLog().info("Use input file: " + inputFile);

            SortedProperties p = new SortedProperties();

            if (inputFile.exists()) {
                Reader reader = Files.newReader(inputFile, Charsets.UTF_8);
                try {
                    p.load(reader);
                    reader.close();
                } finally {
                    Closeables.close(reader, true);
                }
            }
            Set existingId = p.stringPropertyNames();

            Set newIds = new HashSet<>();

            // get all detected ids
            for (String helpId : helpIds) {
                newIds.add(removeQuote(helpId));
            }

            if (strictMode) {

                // remove all obsolete ids
                for (String s : existingId) {
                    if (!newIds.contains(s)) {
                        p.remove(s);
                    }
                }

                // update existing ids
                existingId.retainAll(newIds);
            } else {

                // remove all existing ids (no need to treat them again)
                newIds.removeAll(existingId);
            }

            if (newIds.isEmpty()) {

                getLog().info("No keys to add.");
            } else {

                if (strictMode) {
                    getLog().info("Regenerate files with " + newIds.size() + " keys.");
                } else {
                    getLog().info("Add " + newIds.size() + " keys.");
                }

                for (String helpId : newIds) {
                    if (!p.containsKey(helpId)) {
                        p.put(helpId, "");
                    }
                }

                Writer writer = Files.newWriter(inputFile, Charsets.UTF_8);
                try {
                    p.store(writer, "Generated by " + getClass().getName());
                    writer.close();
                } finally {
                    Closeables.close(writer, true);
                }

            }
        }
    }

    @Override
    protected void postDoAction() {
        helpIds.clear();
    }

    @Override
    public File getTargetDirectory() {
        return getOutputHelpIds();
    }

    @Override
    public void setTargetDirectory(File targetDirectory) {
        setOutputHelpIds(targetDirectory);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy