blob: af50e5503e1644067c89323c158b895c6b70e9d7 [file] [log] [blame]
// Copyright 2022 The Bazel Authors. All rights reserved.
//
// 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.google.devtools.build.docgen.release;
import com.google.devtools.common.options.Option;
import com.google.devtools.common.options.OptionDocumentationCategory;
import com.google.devtools.common.options.OptionEffectTag;
import com.google.devtools.common.options.OptionsBase;
/** Command line options for the TOC updater. */
public class TableOfContentsOptions extends OptionsBase {
@Option(
name = "input",
abbrev = 'i',
defaultValue = "",
documentationCategory = OptionDocumentationCategory.UNCATEGORIZED,
effectTags = {OptionEffectTag.UNKNOWN},
help = "Path to a YAML file that contains the old table of contents.")
public String inputPath;
@Option(
name = "output",
abbrev = 'o',
defaultValue = "",
documentationCategory = OptionDocumentationCategory.UNCATEGORIZED,
effectTags = {OptionEffectTag.UNKNOWN},
help = "Path of the YAML file where the new TOC should be written to.")
public String outputPath;
@Option(
name = "version",
abbrev = 'v',
defaultValue = "",
documentationCategory = OptionDocumentationCategory.UNCATEGORIZED,
effectTags = {OptionEffectTag.UNKNOWN},
help = "The name of the Bazel release that should be included in the TOC.")
public String version;
@Option(
name = "max_releases",
abbrev = 'm',
defaultValue = "5",
documentationCategory = OptionDocumentationCategory.UNCATEGORIZED,
effectTags = {OptionEffectTag.UNKNOWN},
help = "Maximum number of Bazel releases that should be included in the TOC.")
public int maxReleases;
@Option(
name = "help",
abbrev = 'h',
defaultValue = "false",
documentationCategory = OptionDocumentationCategory.UNCATEGORIZED,
effectTags = {OptionEffectTag.UNKNOWN},
help = "Prints the help string.")
public boolean printHelp;
public boolean isValid() {
return !inputPath.isEmpty() && !outputPath.isEmpty() && !version.isEmpty() && maxReleases > 0;
}
}