| // 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; |
| } |
| } |