mirror of
https://github.com/Kitware/CMake.git
synced 2025-05-09 23:08:18 +08:00

- Introduce the `std::string Format(std:string)` method - Simplify the algorithm to use `cmTokenizedView()` instead of pointers manipulation and slow iostreams - Formatted text chunks are collected as a sequence of string views to join once at the end
34 lines
986 B
C++
34 lines
986 B
C++
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
|
#pragma once
|
|
|
|
#include "cmConfigure.h" // IWYU pragma: keep
|
|
|
|
#include <cstddef>
|
|
#include <iosfwd>
|
|
#include <string>
|
|
|
|
class cmDocumentationSection;
|
|
|
|
/** Print documentation in a simple text format. */
|
|
class cmDocumentationFormatter
|
|
{
|
|
public:
|
|
std::string Format(std::string text) const;
|
|
void PrintSection(std::ostream& os, cmDocumentationSection const& section);
|
|
void PrintFormatted(std::ostream& os, std::string const& text) const
|
|
{
|
|
os << this->Format(text);
|
|
}
|
|
void SetIndent(std::size_t indent) { this->TextIndent = indent; }
|
|
|
|
static constexpr std::size_t TEXT_WIDTH = 77u;
|
|
|
|
private:
|
|
void PrintPreformatted(std::ostream& os, std::string const&) const;
|
|
void PrintParagraph(std::ostream& os, std::string const&) const;
|
|
void PrintColumn(std::ostream& os, std::string const&) const;
|
|
|
|
std::size_t TextIndent = 0u;
|
|
};
|