ENH: Added support to write multiple help options with one command line. Output files can now also be specified for the help options.
This commit is contained in:
parent
b85f000e26
commit
1cecf7b5aa
|
@ -93,7 +93,7 @@ void CMakeErrorHandler(const char* message, const char* title, bool&, void* clie
|
||||||
int main(int argc, char** argv)
|
int main(int argc, char** argv)
|
||||||
{
|
{
|
||||||
cmDocumentation doc;
|
cmDocumentation doc;
|
||||||
if(cmDocumentation::Type ht = doc.CheckOptions(argc, argv))
|
if(doc.CheckOptions(argc, argv))
|
||||||
{
|
{
|
||||||
cmake hcm;
|
cmake hcm;
|
||||||
std::vector<cmDocumentationEntry> commands;
|
std::vector<cmDocumentationEntry> commands;
|
||||||
|
@ -103,8 +103,7 @@ int main(int argc, char** argv)
|
||||||
doc.SetDescriptionSection(cmDocumentationDescription);
|
doc.SetDescriptionSection(cmDocumentationDescription);
|
||||||
doc.SetOptionsSection(cmDocumentationOptions);
|
doc.SetOptionsSection(cmDocumentationOptions);
|
||||||
doc.SetCommandsSection(&commands[0]);
|
doc.SetCommandsSection(&commands[0]);
|
||||||
doc.PrintDocumentation(ht, std::cout);
|
return doc.PrintRequestedDocumentation(std::cout)? 0:1;
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool debug = false;
|
bool debug = false;
|
||||||
|
|
|
@ -178,17 +178,69 @@ void cmDocumentation::PrintDocumentation(Type ht, std::ostream& os)
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
cmDocumentation::Type cmDocumentation::CheckOptions(int argc, char** argv)
|
bool cmDocumentation::PrintRequestedDocumentation(std::ostream& os)
|
||||||
|
{
|
||||||
|
bool result = true;
|
||||||
|
|
||||||
|
// Loop over requested documentation types.
|
||||||
|
for(RequestedMapType::const_iterator i = this->RequestedMap.begin();
|
||||||
|
i != this->RequestedMap.end(); ++i)
|
||||||
|
{
|
||||||
|
// If a file name was given, use it. Otherwise, default to the
|
||||||
|
// given stream.
|
||||||
|
std::ofstream* fout = 0;
|
||||||
|
std::ostream* s = &os;
|
||||||
|
if(i->second.length() > 0)
|
||||||
|
{
|
||||||
|
#ifdef _WIN32
|
||||||
|
fout = new ofstream(i->second.c_str(), ios::out | ios::binary);
|
||||||
|
#else
|
||||||
|
fout = new ofstream(i->second.c_str(), ios::out);
|
||||||
|
#endif
|
||||||
|
if(fout)
|
||||||
|
{
|
||||||
|
s = fout;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Print this documentation type to the stream.
|
||||||
|
this->PrintDocumentation(i->first, *s);
|
||||||
|
|
||||||
|
// Check for error.
|
||||||
|
if(!*s)
|
||||||
|
{
|
||||||
|
result = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Close the file if we wrote one.
|
||||||
|
if(fout)
|
||||||
|
{
|
||||||
|
delete fout;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------
|
||||||
|
bool cmDocumentation::CheckOptions(int argc, char** argv)
|
||||||
{
|
{
|
||||||
// Providing zero arguments gives usage information.
|
// Providing zero arguments gives usage information.
|
||||||
if(argc == 1)
|
if(argc == 1)
|
||||||
{
|
{
|
||||||
return cmDocumentation::Usage;
|
this->RequestedMap[cmDocumentation::Usage] = "";
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Search for supported help options.
|
// Search for supported help options.
|
||||||
|
bool result = false;
|
||||||
for(int i=1; i < argc; ++i)
|
for(int i=1; i < argc; ++i)
|
||||||
{
|
{
|
||||||
|
// Check if this is a supported help option.
|
||||||
|
Type type = cmDocumentation::None;
|
||||||
if((strcmp(argv[i], "-help") == 0) ||
|
if((strcmp(argv[i], "-help") == 0) ||
|
||||||
(strcmp(argv[i], "--help") == 0) ||
|
(strcmp(argv[i], "--help") == 0) ||
|
||||||
(strcmp(argv[i], "/?") == 0) ||
|
(strcmp(argv[i], "/?") == 0) ||
|
||||||
|
@ -196,33 +248,48 @@ cmDocumentation::Type cmDocumentation::CheckOptions(int argc, char** argv)
|
||||||
(strcmp(argv[i], "-h") == 0) ||
|
(strcmp(argv[i], "-h") == 0) ||
|
||||||
(strcmp(argv[i], "-H") == 0))
|
(strcmp(argv[i], "-H") == 0))
|
||||||
{
|
{
|
||||||
return cmDocumentation::Usage;
|
type = cmDocumentation::Usage;
|
||||||
}
|
}
|
||||||
if(strcmp(argv[i], "--help-full") == 0)
|
else if(strcmp(argv[i], "--help-full") == 0)
|
||||||
{
|
{
|
||||||
return cmDocumentation::Full;
|
type = cmDocumentation::Full;
|
||||||
}
|
}
|
||||||
if(strcmp(argv[i], "--help-html") == 0)
|
else if(strcmp(argv[i], "--help-html") == 0)
|
||||||
{
|
{
|
||||||
return cmDocumentation::HTML;
|
type = cmDocumentation::HTML;
|
||||||
}
|
}
|
||||||
if(strcmp(argv[i], "--help-man") == 0)
|
else if(strcmp(argv[i], "--help-man") == 0)
|
||||||
{
|
{
|
||||||
return cmDocumentation::Man;
|
type = cmDocumentation::Man;
|
||||||
}
|
}
|
||||||
if(strcmp(argv[i], "--copyright") == 0)
|
else if(strcmp(argv[i], "--copyright") == 0)
|
||||||
{
|
{
|
||||||
return cmDocumentation::Copyright;
|
type = cmDocumentation::Copyright;
|
||||||
}
|
}
|
||||||
if((strcmp(argv[i], "--version") == 0) ||
|
else if((strcmp(argv[i], "--version") == 0) ||
|
||||||
(strcmp(argv[i], "-version") == 0) ||
|
(strcmp(argv[i], "-version") == 0) ||
|
||||||
(strcmp(argv[i], "-V") == 0) ||
|
(strcmp(argv[i], "-V") == 0) ||
|
||||||
(strcmp(argv[i], "/V") == 0))
|
(strcmp(argv[i], "/V") == 0))
|
||||||
{
|
{
|
||||||
return cmDocumentation::Version;
|
type = cmDocumentation::Version;
|
||||||
|
}
|
||||||
|
if(type)
|
||||||
|
{
|
||||||
|
// This is a help option. See if there is a file name given.
|
||||||
|
result = true;
|
||||||
|
if((i+1 < argc) && (argv[i+1][0] != '-') &&
|
||||||
|
(strcmp(argv[i+1], "/V") != 0) && (strcmp(argv[i+1], "/?") != 0))
|
||||||
|
{
|
||||||
|
this->RequestedMap[type] = argv[i+1];
|
||||||
|
i = i+1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this->RequestedMap[type] = "";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return cmDocumentation::None;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
//----------------------------------------------------------------------------
|
//----------------------------------------------------------------------------
|
||||||
|
|
|
@ -32,11 +32,19 @@ public:
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check command line arguments for documentation options. Returns
|
* Check command line arguments for documentation options. Returns
|
||||||
* the type of help to be provided. If non-zero, the result should
|
* true if documentation options are found, and false otherwise.
|
||||||
* be passed to PrintDocumentation to produce the desired
|
* When true is returned, PrintRequestedDocumentation should be
|
||||||
* documentation.
|
* called.
|
||||||
*/
|
*/
|
||||||
Type CheckOptions(int argc, char** argv);
|
bool CheckOptions(int argc, char** argv);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Print help requested on the command line. Call after
|
||||||
|
* CheckOptions returns true. Returns true on success, and false
|
||||||
|
* otherwise. Failure can occur when output files specified on the
|
||||||
|
* command line cannot be written.
|
||||||
|
*/
|
||||||
|
bool PrintRequestedDocumentation(std::ostream& os);
|
||||||
|
|
||||||
/** Print help of the given type. */
|
/** Print help of the given type. */
|
||||||
void PrintDocumentation(Type ht, std::ostream& os);
|
void PrintDocumentation(Type ht, std::ostream& os);
|
||||||
|
@ -134,6 +142,9 @@ private:
|
||||||
Form CurrentForm;
|
Form CurrentForm;
|
||||||
const char* TextIndent;
|
const char* TextIndent;
|
||||||
int TextWidth;
|
int TextWidth;
|
||||||
|
|
||||||
|
typedef std::map<Type, cmStdString> RequestedMapType;
|
||||||
|
RequestedMapType RequestedMap;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -93,7 +93,7 @@ int main(int ac, char** av)
|
||||||
int do_cmake(int ac, char** av)
|
int do_cmake(int ac, char** av)
|
||||||
{
|
{
|
||||||
cmDocumentation doc;
|
cmDocumentation doc;
|
||||||
if(cmDocumentation::Type ht = doc.CheckOptions(ac, av))
|
if(doc.CheckOptions(ac, av))
|
||||||
{
|
{
|
||||||
// Construct and print requested documentation.
|
// Construct and print requested documentation.
|
||||||
cmake hcm;
|
cmake hcm;
|
||||||
|
@ -107,7 +107,7 @@ int do_cmake(int ac, char** av)
|
||||||
doc.SetGeneratorsSection(&generators[0]);
|
doc.SetGeneratorsSection(&generators[0]);
|
||||||
doc.SetOptionsSection(cmDocumentationOptions);
|
doc.SetOptionsSection(cmDocumentationOptions);
|
||||||
doc.SetCommandsSection(&commands[0]);
|
doc.SetCommandsSection(&commands[0]);
|
||||||
doc.PrintDocumentation(ht, std::cout);
|
int result = doc.PrintRequestedDocumentation(std::cout)? 0:1;
|
||||||
|
|
||||||
// If we were run with no arguments, but a CMakeLists.txt file
|
// If we were run with no arguments, but a CMakeLists.txt file
|
||||||
// exists, the user may have been trying to use the old behavior
|
// exists, the user may have been trying to use the old behavior
|
||||||
|
@ -121,7 +121,7 @@ int do_cmake(int ac, char** av)
|
||||||
doc.Print(cmDocumentation::UsageForm, std::cerr);
|
doc.Print(cmDocumentation::UsageForm, std::cerr);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
return 0;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wiz = false;
|
bool wiz = false;
|
||||||
|
|
Loading…
Reference in New Issue