ENH: Added support to --help to print help for a single command.

This commit is contained in:
Brad King 2003-08-05 18:10:45 -04:00
parent df2280a7ab
commit c4794319c7
2 changed files with 55 additions and 10 deletions

View File

@ -21,18 +21,25 @@
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
static const cmDocumentationEntry cmDocumentationStandardOptions[] = static const cmDocumentationEntry cmDocumentationStandardOptions[] =
{ {
{"--copyright", "Print the CMake copyright and exit.", 0}, {"--copyright [file]", "Print the CMake copyright and exit.",
{"--help", "Print usage information and exit.", "If a file is specified, the copyright is written into it."},
"Usage describes the basic command line interface and its options."}, {"--help [command]", "Print usage information and exit.",
{"--help-full", "Print full help and exit.", "Usage describes the basic command line interface and its options. "
"If a listfile command is specified, help for that specific command is "
"printed."},
{"--help-full [file]", "Print full help and exit.",
"Full help displays most of the documentation provided by the UNIX " "Full help displays most of the documentation provided by the UNIX "
"man page. It is provided for use on non-UNIX platforms, but is " "man page. It is provided for use on non-UNIX platforms, but is "
"also convenient if the man page is not installed."}, "also convenient if the man page is not installed. If a file is "
{"--help-html", "Print full help in HTML format.", "specified, the help is written into it."},
"This option is used by CMake authors to help produce web pages."}, {"--help-html [file]", "Print full help in HTML format.",
{"--help-man", "Print a UNIX man page and exit.", "This option is used by CMake authors to help produce web pages. "
"This option is used by CMake authors to generate the UNIX man page."}, "If a file is specified, the help is written into it."},
{"--version", "Show program name/version banner and exit.", 0}, {"--help-man [file]", "Print a UNIX man page and exit.",
"This option is used by the cmake build to generate the UNIX man page. "
"If a file is specified, the help is written into it."},
{"--version [file]", "Show program name/version banner and exit.",
"If a file is specified, the version is written into it."},
{0,0,0} {0,0,0}
}; };
@ -186,6 +193,28 @@ bool cmDocumentation::PrintRequestedDocumentation(std::ostream& os)
for(RequestedMapType::const_iterator i = this->RequestedMap.begin(); for(RequestedMapType::const_iterator i = this->RequestedMap.begin();
i != this->RequestedMap.end(); ++i) i != this->RequestedMap.end(); ++i)
{ {
// Special case for printing help for a single command.
if(i->first == cmDocumentation::Usage && i->second.length() > 0 &&
!this->CommandsSection.empty())
{
// Check if the argument to the usage request was a command.
for(cmDocumentationEntry* entry = &this->CommandsSection[0];
entry->brief; ++entry)
{
if(entry->name && (strcmp(entry->name, i->second.c_str()) == 0))
{
this->PrintDocumentationCommand(os, entry);
return true;
}
}
// Argument was not a command. Complain.
os << "Help argument \"" << i->second.c_str()
<< "\" is not a CMake command. "
<< "Use --help-full to see all commands.\n";
return false;
}
// If a file name was given, use it. Otherwise, default to the // If a file name was given, use it. Otherwise, default to the
// given stream. // given stream.
std::ofstream* fout = 0; std::ofstream* fout = 0;
@ -783,6 +812,20 @@ void cmDocumentation::PrintDocumentationMan(std::ostream& os)
this->Print(ManForm, os); this->Print(ManForm, os);
} }
//----------------------------------------------------------------------------
void cmDocumentation::PrintDocumentationCommand(std::ostream& os,
cmDocumentationEntry* entry)
{
cmDocumentationEntry singleCommandSection[3] =
{
{entry->name, entry->brief, entry->full},
{0,0,0}
};
this->ClearSections();
this->AddSection(0, &singleCommandSection[0]);
this->Print(TextForm, os);
}
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
void cmDocumentation::CreateUsageDocumentation() void cmDocumentation::CreateUsageDocumentation()
{ {

View File

@ -123,6 +123,8 @@ private:
void PrintDocumentationFull(std::ostream& os); void PrintDocumentationFull(std::ostream& os);
void PrintDocumentationHTML(std::ostream& os); void PrintDocumentationHTML(std::ostream& os);
void PrintDocumentationMan(std::ostream& os); void PrintDocumentationMan(std::ostream& os);
void PrintDocumentationCommand(std::ostream& os,
cmDocumentationEntry* entry);
void CreateUsageDocumentation(); void CreateUsageDocumentation();
void CreateFullDocumentation(); void CreateFullDocumentation();