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

com.github.rvesse.airline.help.markdown.MarkdownCommandUsageGenerator Maven / Gradle / Ivy

There is a newer version: 3.0.0
Show newest version
/**
 * Copyright (C) 2010-16 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.github.rvesse.airline.help.markdown;

import static com.github.rvesse.airline.help.UsageHelper.DEFAULT_OPTION_COMPARATOR;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.List;

import org.apache.commons.lang3.StringUtils;

import com.github.rvesse.airline.help.common.AbstractPrintedCommandUsageGenerator;
import com.github.rvesse.airline.help.sections.HelpSection;
import com.github.rvesse.airline.io.printers.UsagePrinter;
import com.github.rvesse.airline.model.ArgumentsMetadata;
import com.github.rvesse.airline.model.CommandMetadata;
import com.github.rvesse.airline.model.MetadataLoader;
import com.github.rvesse.airline.model.OptionMetadata;
import com.github.rvesse.airline.model.ParserMetadata;

public class MarkdownCommandUsageGenerator extends AbstractPrintedCommandUsageGenerator {

    private final MarkdownUsageHelper helper;

    public MarkdownCommandUsageGenerator() {
        this(DEFAULT_COLUMNS, DEFAULT_OPTION_COMPARATOR, false);
    }

    public MarkdownCommandUsageGenerator(boolean includeHidden) {
        this(DEFAULT_COLUMNS, DEFAULT_OPTION_COMPARATOR, includeHidden);
    }

    public MarkdownCommandUsageGenerator(int columns) {
        this(columns, DEFAULT_OPTION_COMPARATOR, false);
    }

    public MarkdownCommandUsageGenerator(int columns, boolean includeHidden) {
        this(columns, DEFAULT_OPTION_COMPARATOR, includeHidden);
    }

    public MarkdownCommandUsageGenerator(int columns, Comparator optionComparator,
            boolean includeHidden) {
        super(columns, optionComparator, includeHidden);
        helper = createHelper(optionComparator, includeHidden);
    }

    protected MarkdownUsageHelper createHelper(Comparator optionComparator,
            boolean includeHidden) {
        return new MarkdownUsageHelper(optionComparator, includeHidden);
    }

    @Override
    public  void usage(String programName, String[] groupNames, String commandName, CommandMetadata command,
            ParserMetadata parserConfig, UsagePrinter out) throws IOException {

        if (parserConfig == null) {
            parserConfig = MetadataLoader.loadParser(command.getType());
        }

        // Name and description
        outputDescription(out, programName, groupNames, commandName, command);

        // Find the help sections
        List preSections = new ArrayList();
        List postSections = new ArrayList();
        findHelpSections(command, preSections, postSections);

        // Output pre help sections
        for (HelpSection section : preSections) {
            helper.outputHelpSection(out, section);
        }

        // Synopsis
        List options = outputSynopsis(out, programName, groupNames, commandName, command);

        // Options
        ArgumentsMetadata arguments = command.getArguments();
        if (options.size() > 0 || arguments != null) {
            outputOptionsAndArguments(out, command, options, arguments, parserConfig);
        }

        // Output post help sections
        for (HelpSection section : postSections) {
            helper.outputHelpSection(out, section);
        }
    }

    /**
     * Outputs a documentation section detailing options and their usages
     * 
     * @param out
     *            Usage printer
     * @param command
     *            Command meta-data
     * @param options
     *            Options meta-data
     * @param arguments
     *            Arguments meta-data
     * @param parserConfig
     *            Parser configuration
     * @param 
     *            Command type
     * @throws IOException
     *             Thrown if there is a problem generating usage output
     */
    protected  void outputOptionsAndArguments(UsagePrinter out, CommandMetadata command,
            List options, ArgumentsMetadata arguments, ParserMetadata parserConfig)
            throws IOException {
        helper.outputOptions(out, options);
        helper.outputArguments(out, arguments, parserConfig);
    }

    /**
     * Outputs a documentation section with a synopsis of command usage
     * 
     * @param out
     *            Usage printer
     * @param programName
     *            Program name
     * @param groupNames
     *            Group name(s)
     * @param commandName
     *            Command name
     * @param command
     *            Command meta-data
     * @return Collection of all options (Global, Group and Command)
     * @throws IOException
     *             Thrown if there is a problem generating usage output
     */
    protected List outputSynopsis(UsagePrinter out, String programName, String[] groupNames,
            String commandName, CommandMetadata command) throws IOException {
        out.append("# SYNOPSIS").newline().newline();

        List options = new ArrayList<>();
        if (programName != null) {
            out.append(String.format("`%s`", programName));
            helper.outputOptionsSynopsis(out, command.getGlobalOptions());
            options.addAll(command.getGlobalOptions());
        }
        if (groupNames != null) {
            for (String group : groupNames) {
                out.append(String.format("`%s`", group));
            }
            helper.outputOptionsSynopsis(out, command.getGroupOptions());
            options.addAll(command.getGroupOptions());
        }
        out.append(String.format("`%s`", commandName));
        helper.outputOptionsSynopsis(out, command.getCommandOptions());
        options.addAll(command.getCommandOptions());

        // command arguments (optional)
        if (command.getArguments() != null) {
            out.append("[ `--` ]");
            helper.outputArgumentsSynopsis(out, command.getArguments());
        }
        out.newline();
        out.newline();
        return options;
    }

    /**
     * Outputs a documentation section describing the command
     * 
     * @param out
     *            Usage printer
     * @param programName
     *            Program name
     * @param groupNames
     *            Group name(s)
     * @param commandName
     *            Command name
     * @param command
     *            Command meta-data
     * @throws IOException
     *             Thrown if there is a problem generating usage output
     */
    protected void outputDescription(UsagePrinter out, String programName, String[] groupNames, String commandName,
            CommandMetadata command) throws IOException {
        out.append("# NAME").newline().newline();

        if (StringUtils.isNotEmpty(programName)) {
            out = out.append(String.format("`%s`", programName));
        }
        if (groupNames != null) {
            for (String group : groupNames) {
                out.append(String.format("`%s`", group));
            }
        }
        out.append(String.format("`%s`", commandName));
        out.append("-").append(command.getDescription()).newline().newline();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy