// -*- C++ -*- /** * \file texstream.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author Enrico Forestieri * * Full author contact details are available in file CREDITS. */ #ifndef LYX_TEXSTREAM_H #define LYX_TEXSTREAM_H #include "support/docstream.h" #include "support/unique_ptr.h" namespace lyx { class TexRow; // declared below class otexstringstream; /** Wrapper class for odocstream. This class is used to automatically count the lines of the exported latex code. */ class otexrowstream { public: /// explicit otexrowstream(odocstream & os, bool enable = true); /// defaulted ~otexrowstream(); /// odocstream & os() { return os_; } /// TexRow & texrow() { return *texrow_; } /// unique_ptr releaseTexRow(); /// void put(char_type const & c); /// void append(docstring const & str, TexRow texrow); private: /// odocstream & os_; /// unique_ptr texrow_; }; /// otexrowstream & operator<<(otexrowstream &, odocstream_manip); /// otexrowstream & operator<<(otexrowstream &, docstring const &); /// otexrowstream & operator<<(otexrowstream &, std::string const &); /// otexrowstream & operator<<(otexrowstream &, char const *); /// otexrowstream & operator<<(otexrowstream &, char); /// template otexrowstream & operator<<(otexrowstream & ots, Type value); /** Subclass for otexrowstream. This class is used to ensure that no blank lines may be inadvertently output. To this end, use the special variables "breakln" and "safebreakln" as if they were iomanip's to ensure that the next output will start at the beginning of a line. Using "breakln", a '\n' char will be output if needed, while using "safebreakln", "%\n" will be output if needed. The class also records the last output character and can tell whether a paragraph break was just output. */ class otexstream : public otexrowstream { public: /// explicit otexstream(odocstream & os, bool enable = true) : otexrowstream(os, enable), canbreakline_(false), protectspace_(false), parbreak_(true), lastchar_(0) {} /// void put(char_type const & c); /// void canBreakLine(bool breakline) { canbreakline_ = breakline; } /// bool canBreakLine() const { return canbreakline_; } /// void protectSpace(bool protectspace) { protectspace_ = protectspace; } /// bool protectSpace() const { return protectspace_; } /// void lastChar(char_type const & c) { parbreak_ = (!canbreakline_ && c == '\n'); canbreakline_ = (c != '\n'); lastchar_ = c; } /// char_type lastChar() const { return lastchar_; } /// bool afterParbreak() const { return parbreak_; } private: /// bool canbreakline_; /// bool protectspace_; /// bool parbreak_; /// char_type lastchar_; }; /// Helper structs for breaking a line struct BreakLine { char n; }; struct SafeBreakLine { char n; }; extern BreakLine breakln; extern SafeBreakLine safebreakln; /// otexstream & operator<<(otexstream &, BreakLine); /// otexstream & operator<<(otexstream &, SafeBreakLine); /// otexstream & operator<<(otexstream &, odocstream_manip); /// otexstream & operator<<(otexstream &, docstring const &); /// otexstream & operator<<(otexstream &, std::string const &); /// otexstream & operator<<(otexstream &, char const *); /// otexstream & operator<<(otexstream &, char); /// template otexstream & operator<<(otexstream & ots, Type value); } #endif