From a2c19a4d46b82f747d97ad0005887ce44c89af72 Mon Sep 17 00:00:00 2001 From: Andy Cedilnik Date: Thu, 16 Sep 2004 10:27:17 -0400 Subject: ENH: Condense help string, add support for setting line length and make it work --- Source/kwsys/CommandLineArguments.cxx | 39 ++++++++++++++++++++++++-------- Source/kwsys/CommandLineArguments.hxx.in | 2 +- 2 files changed, 31 insertions(+), 10 deletions(-) diff --git a/Source/kwsys/CommandLineArguments.cxx b/Source/kwsys/CommandLineArguments.cxx index 27bf6e6..7296ed3 100644 --- a/Source/kwsys/CommandLineArguments.cxx +++ b/Source/kwsys/CommandLineArguments.cxx @@ -465,6 +465,17 @@ const char* CommandLineArguments::GetHelp(const char* arg) } //---------------------------------------------------------------------------- +void CommandLineArguments::SetLineLength(unsigned int ll) +{ + if ( ll < 9 || ll > 1000 ) + { + return; + } + this->LineLength = ll; + this->GenerateHelp(); +} + +//---------------------------------------------------------------------------- void CommandLineArguments::GenerateHelp() { kwsys_ios::ostringstream str; @@ -528,9 +539,9 @@ void CommandLineArguments::GenerateHelp() switch ( this->Internals->Callbacks[*sit].ArgumentType ) { case CommandLineArguments::NO_ARGUMENT: clen += 0; break; - case CommandLineArguments::CONCAT_ARGUMENT: clen += 6; break; - case CommandLineArguments::SPACE_ARGUMENT: clen += 7; break; - case CommandLineArguments::EQUAL_ARGUMENT: clen += 7; break; + case CommandLineArguments::CONCAT_ARGUMENT: clen += 3; break; + case CommandLineArguments::SPACE_ARGUMENT: clen += 4; break; + case CommandLineArguments::EQUAL_ARGUMENT: clen += 4; break; } if ( clen > maxlen ) { @@ -539,9 +550,11 @@ void CommandLineArguments::GenerateHelp() } } + maxlen += 2; // For the space after option + // Create format for that string char format[80]; - sprintf(format, "%%%ds", static_cast(maxlen)); + sprintf(format, "%%%ds ", static_cast(maxlen-2)); // Print help for each option @@ -558,15 +571,14 @@ void CommandLineArguments::GenerateHelp() switch ( this->Internals->Callbacks[*sit].ArgumentType ) { case CommandLineArguments::NO_ARGUMENT: break; - case CommandLineArguments::CONCAT_ARGUMENT: strcat(argument, "option"); break; - case CommandLineArguments::SPACE_ARGUMENT: strcat(argument, " option"); break; - case CommandLineArguments::EQUAL_ARGUMENT: strcat(argument, "=option"); break; + case CommandLineArguments::CONCAT_ARGUMENT: strcat(argument, "opt"); break; + case CommandLineArguments::SPACE_ARGUMENT: strcat(argument, " opt"); break; + case CommandLineArguments::EQUAL_ARGUMENT: strcat(argument, "=opt"); break; } char buffer[80]; sprintf(buffer, format, argument); str << buffer; } - str << "\t"; const char* ptr = this->Internals->Callbacks[mpit->first].Help; int len = strlen(ptr); int cnt = 0; @@ -589,7 +601,6 @@ void CommandLineArguments::GenerateHelp() { str << " "; } - str << "\t"; } CommandLineArguments::Internal::String::size_type skip = len; if ( skip > this->LineLength - maxlen ) @@ -614,6 +625,16 @@ void CommandLineArguments::GenerateHelp() cnt ++; } } + /* + // This can help debugging help string + str << endl; + unsigned int cc; + for ( cc = 0; cc < this->LineLength; cc ++ ) + { + str << cc % 10; + } + str << endl; + */ this->Help = str.str(); } diff --git a/Source/kwsys/CommandLineArguments.hxx.in b/Source/kwsys/CommandLineArguments.hxx.in index a88ef26..c07dff9 100644 --- a/Source/kwsys/CommandLineArguments.hxx.in +++ b/Source/kwsys/CommandLineArguments.hxx.in @@ -134,7 +134,7 @@ public: /** * Get / Set the help line length. Default length is 80. */ - void SetLineLength(); + void SetLineLength(unsigned int); unsigned int GetLineLength(); protected: -- cgit v0.12