Putting all the standard tool options into a "Generic" category.

Summary:
This puts all the options that CommandLine.cpp implements into a category so that the APIs to hide options can not hide based on the generic category instead of string matching a partial list of argument strings.

This patch is pretty simple and straight forward but it does impact the -help output of all tools using cl::opt. Specifically the options implemented in CommandLine.cpp (help, help-list, help-hidden, help-list-hidden, print-options, print-all-options, version) are all grouped together into an Option category, and these options are never hidden by the cl::HideUnrelatedOptions API.

Reviewers: dexonsmith, chandlerc, majnemer

Subscribers: llvm-commits

Differential Revision: http://reviews.llvm.org/D7150

llvm-svn: 227093
This commit is contained in:
Chris Bieneman 2015-01-26 16:56:00 +00:00
parent 9e3a5db000
commit 831fc5e87d
2 changed files with 21 additions and 9 deletions

View File

@ -1665,39 +1665,45 @@ static HelpPrinterWrapper WrappedNormalPrinter(UncategorizedNormalPrinter,
static HelpPrinterWrapper WrappedHiddenPrinter(UncategorizedHiddenPrinter, static HelpPrinterWrapper WrappedHiddenPrinter(UncategorizedHiddenPrinter,
CategorizedHiddenPrinter); CategorizedHiddenPrinter);
// Define a category for generic options that all tools should have.
static cl::OptionCategory GenericCategory("Generic Options");
// Define uncategorized help printers. // Define uncategorized help printers.
// -help-list is hidden by default because if Option categories are being used // -help-list is hidden by default because if Option categories are being used
// then -help behaves the same as -help-list. // then -help behaves the same as -help-list.
static cl::opt<HelpPrinter, true, parser<bool>> HLOp( static cl::opt<HelpPrinter, true, parser<bool>> HLOp(
"help-list", "help-list",
cl::desc("Display list of available options (-help-list-hidden for more)"), cl::desc("Display list of available options (-help-list-hidden for more)"),
cl::location(UncategorizedNormalPrinter), cl::Hidden, cl::ValueDisallowed); cl::location(UncategorizedNormalPrinter), cl::Hidden, cl::ValueDisallowed,
cl::cat(GenericCategory));
static cl::opt<HelpPrinter, true, parser<bool>> static cl::opt<HelpPrinter, true, parser<bool>>
HLHOp("help-list-hidden", cl::desc("Display list of all available options"), HLHOp("help-list-hidden", cl::desc("Display list of all available options"),
cl::location(UncategorizedHiddenPrinter), cl::Hidden, cl::location(UncategorizedHiddenPrinter), cl::Hidden,
cl::ValueDisallowed); cl::ValueDisallowed, cl::cat(GenericCategory));
// Define uncategorized/categorized help printers. These printers change their // Define uncategorized/categorized help printers. These printers change their
// behaviour at runtime depending on whether one or more Option categories have // behaviour at runtime depending on whether one or more Option categories have
// been declared. // been declared.
static cl::opt<HelpPrinterWrapper, true, parser<bool>> static cl::opt<HelpPrinterWrapper, true, parser<bool>>
HOp("help", cl::desc("Display available options (-help-hidden for more)"), HOp("help", cl::desc("Display available options (-help-hidden for more)"),
cl::location(WrappedNormalPrinter), cl::ValueDisallowed); cl::location(WrappedNormalPrinter), cl::ValueDisallowed,
cl::cat(GenericCategory));
static cl::opt<HelpPrinterWrapper, true, parser<bool>> static cl::opt<HelpPrinterWrapper, true, parser<bool>>
HHOp("help-hidden", cl::desc("Display all available options"), HHOp("help-hidden", cl::desc("Display all available options"),
cl::location(WrappedHiddenPrinter), cl::Hidden, cl::ValueDisallowed); cl::location(WrappedHiddenPrinter), cl::Hidden, cl::ValueDisallowed,
cl::cat(GenericCategory));
static cl::opt<bool> PrintOptions( static cl::opt<bool> PrintOptions(
"print-options", "print-options",
cl::desc("Print non-default options after command line parsing"), cl::desc("Print non-default options after command line parsing"),
cl::Hidden, cl::init(false)); cl::Hidden, cl::init(false), cl::cat(GenericCategory));
static cl::opt<bool> PrintAllOptions( static cl::opt<bool> PrintAllOptions(
"print-all-options", "print-all-options",
cl::desc("Print all option values after command line parsing"), cl::Hidden, cl::desc("Print all option values after command line parsing"), cl::Hidden,
cl::init(false)); cl::init(false), cl::cat(GenericCategory));
void HelpPrinterWrapper::operator=(bool Value) { void HelpPrinterWrapper::operator=(bool Value) {
if (Value == false) if (Value == false)
@ -1802,7 +1808,8 @@ static VersionPrinter VersionPrinterInstance;
static cl::opt<VersionPrinter, true, parser<bool>> static cl::opt<VersionPrinter, true, parser<bool>>
VersOp("version", cl::desc("Display the version of this program"), VersOp("version", cl::desc("Display the version of this program"),
cl::location(VersionPrinterInstance), cl::ValueDisallowed); cl::location(VersionPrinterInstance), cl::ValueDisallowed,
cl::cat(GenericCategory));
// Utility function for printing the help message. // Utility function for printing the help message.
void cl::PrintHelpMessage(bool Hidden, bool Categorized) { void cl::PrintHelpMessage(bool Hidden, bool Categorized) {
@ -1848,8 +1855,8 @@ void cl::HideUnrelatedOptions(cl::OptionCategory &Category) {
StringMap<cl::Option *> Options; StringMap<cl::Option *> Options;
cl::getRegisteredOptions(Options); cl::getRegisteredOptions(Options);
for (auto &I : Options) { for (auto &I : Options) {
if (I.second->Category != &Category && I.first() != "help" && if (I.second->Category != &Category &&
I.first() != "version") I.second->Category != &GenericCategory)
I.second->setHiddenFlag(cl::ReallyHidden); I.second->setHiddenFlag(cl::ReallyHidden);
} }
} }

View File

@ -240,6 +240,11 @@ TEST(CommandLineTest, HideUnrelatedOptions) {
<< "Failed to hide extra option."; << "Failed to hide extra option.";
ASSERT_EQ(cl::NotHidden, TestOption2.getOptionHiddenFlag()) ASSERT_EQ(cl::NotHidden, TestOption2.getOptionHiddenFlag())
<< "Hid extra option that should be visable."; << "Hid extra option that should be visable.";
StringMap<cl::Option*> Map;
cl::getRegisteredOptions(Map);
ASSERT_EQ(cl::NotHidden, Map["help"]->getOptionHiddenFlag())
<< "Hid default option that should be visable.";
} }
} // anonymous namespace } // anonymous namespace