ENH: Further improved formatting. HTML/man/help now all have a consistent appearance.

This commit is contained in:
Brad King 2003-02-14 13:28:46 -05:00
parent 2c7a05edd2
commit 0005e70c05
2 changed files with 93 additions and 45 deletions

View File

@ -101,7 +101,10 @@ void cmDocumentation::PrintManSection(std::ostream& os,
os << ".TP\n" os << ".TP\n"
<< ".B " << op->name << "\n" << ".B " << op->name << "\n"
<< op->brief << "\n\n"; << op->brief << "\n\n";
if(op->full) { os << op->full << "\n"; } if(op->full)
{
this->PrintFull(os, op->full, 0, 0);
}
} }
else else
{ {
@ -171,47 +174,11 @@ void cmDocumentation::PrintHTMLEscapes(std::ostream& os, const char* text)
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
void cmDocumentation::PrintHTMLFull(std::ostream& os, const char* text) void cmDocumentation::PrintHTMLPreformatted(std::ostream& os, const char* text)
{ {
const char* line = text; os << "<pre>";
while(*line) cmDocumentation::PrintHTMLEscapes(os, text);
{ os << "</pre>";
// Any lines starting in a space are treated as a preformatted
// section.
std::string preformatted;
while(*line == ' ')
{
for(char ch = *line; ch && ch != '\n'; ++line, ch = *line)
{
preformatted.append(1, ch);
}
if(*line)
{
++line;
preformatted.append(1, '\n');
}
}
if(preformatted.length())
{
os << "<pre>";
this->PrintHTMLEscapes(os, preformatted.c_str());
os << "</pre>";
}
std::string normal;
for(char ch = *line; ch && ch != '\n'; ++line, ch = *line)
{
normal.append(1, ch);
}
if(*line)
{
++line;
normal.append(1, '\n');
}
if(normal.length())
{
this->PrintHTMLEscapes(os, normal.c_str());
}
}
} }
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
@ -239,7 +206,9 @@ void cmDocumentation::PrintHelpHTMLSection(std::ostream& os,
if(op->full) if(op->full)
{ {
os << "<br>"; os << "<br>";
this->PrintHTMLFull(os, op->full); this->PrintFull(os, op->full,
&cmDocumentation::PrintHTMLPreformatted,
&cmDocumentation::PrintHTMLEscapes);
} }
os << "\n"; os << "\n";
os << " </li>\n"; os << " </li>\n";
@ -379,7 +348,8 @@ void cmDocumentation::PrintColumn(std::ostream& os, int width,
int column = 0; int column = 0;
bool newSentence = false; bool newSentence = false;
bool firstLine = true; bool firstLine = true;
bool lastHadBlanks = false;
// Count leading blanks in the text. // Count leading blanks in the text.
int blanks = 0; int blanks = 0;
for(const char* b = l; *b == ' '; ++b) { ++blanks; } for(const char* b = l; *b == ' '; ++b) { ++blanks; }
@ -414,6 +384,22 @@ void cmDocumentation::PrintColumn(std::ostream& os, int width,
} }
else else
{ {
// If this is the first line not beginning in a blank after
// a sequence of lines beginning in blanks, add an extra
// newline.
if(blanks)
{
lastHadBlanks = true;
}
else
{
if(lastHadBlanks)
{
os << "\n";
}
lastHadBlanks = false;
}
// First word on line. Print indentation unless this is the // First word on line. Print indentation unless this is the
// first line. // first line.
os << (firstLine?"":indent); os << (firstLine?"":indent);
@ -470,6 +456,65 @@ void cmDocumentation::PrintColumn(std::ostream& os, int width,
} }
} }
//----------------------------------------------------------------------------
void cmDocumentation::PrintFull(std::ostream& os, const char* text,
void (*pPreform)(std::ostream&, const char*),
void (*pNormal)(std::ostream&, const char*))
{
const char* line = text;
while(*line)
{
// Any lines starting in a space are treated as preformatted text.
std::string preformatted;
while(*line == ' ')
{
for(char ch = *line; ch && ch != '\n'; ++line, ch = *line)
{
preformatted.append(1, ch);
}
if(*line)
{
++line;
preformatted.append(1, '\n');
}
}
if(preformatted.length())
{
if(pPreform)
{
pPreform(os, preformatted.c_str());
}
else
{
os << preformatted << "\n";
}
}
// Other lines are treated as normal text.
std::string normal;
for(char ch = *line; ch && ch != '\n'; ++line, ch = *line)
{
normal.append(1, ch);
}
if(*line)
{
++line;
normal.append(1, '\n');
}
if(normal.length())
{
if(pNormal)
{
pNormal(os, normal.c_str());
}
else
{
os << normal << "\n";
}
}
}
}
//---------------------------------------------------------------------------- //----------------------------------------------------------------------------
void cmDocumentation::Print(Type ht, std::ostream& os) void cmDocumentation::Print(Type ht, std::ostream& os)
{ {

View File

@ -48,8 +48,11 @@ private:
void PrintManSection(std::ostream& os, const cmDocumentationEntry* section, void PrintManSection(std::ostream& os, const cmDocumentationEntry* section,
const char* name); const char* name);
void PrintHelpSection(std::ostream& os, const cmDocumentationEntry* section); void PrintHelpSection(std::ostream& os, const cmDocumentationEntry* section);
void PrintHTMLEscapes(std::ostream& os, const char* text); static void PrintHTMLEscapes(std::ostream& os, const char* text);
void PrintHTMLFull(std::ostream& os, const char* text); static void PrintHTMLPreformatted(std::ostream& os, const char* text);
void PrintFull(std::ostream& os, const char* text,
void (*pPreform)(std::ostream&, const char*),
void (*pNormal)(std::ostream&, const char*));
void PrintHelpHTMLSection(std::ostream& os, void PrintHelpHTMLSection(std::ostream& os,
const cmDocumentationEntry* section, const cmDocumentationEntry* section,
const char* header); const char* header);