com.github.rvesse.airline.help.markdown.MarkdownCommandUsageGenerator Maven / Gradle / Ivy
/**
* Copyright (C) 2010-15 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 super OptionMetadata> optionComparator,
boolean includeHidden) {
super(columns, optionComparator, includeHidden);
helper = createHelper(optionComparator, includeHidden);
}
protected MarkdownUsageHelper createHelper(Comparator super OptionMetadata> 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
* @throws IOException
*/
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
*/
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
*/
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