2015-01-09 21:07:59 +01:00
|
|
|
// -*- 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 "TexRow.h"
|
|
|
|
#include "support/docstream.h"
|
|
|
|
|
|
|
|
namespace lyx {
|
|
|
|
|
|
|
|
/** Wrapper class for odocstream.
|
|
|
|
This class is used to automatically count the lines of the exported latex
|
2015-10-07 04:02:40 +01:00
|
|
|
code.
|
|
|
|
*/
|
|
|
|
|
|
|
|
class otexrowstream {
|
|
|
|
public:
|
|
|
|
///
|
|
|
|
otexrowstream(odocstream & os, TexRow & texrow)
|
|
|
|
: os_(os), texrow_(texrow) {}
|
|
|
|
///
|
|
|
|
odocstream & os() { return os_; }
|
|
|
|
///
|
|
|
|
TexRow & texrow() { return texrow_; }
|
|
|
|
///
|
|
|
|
void put(char_type const & c);
|
2015-10-13 23:51:50 +01:00
|
|
|
///
|
|
|
|
void append(docstring const &, TexRow const &);
|
2015-10-07 04:02:40 +01:00
|
|
|
private:
|
|
|
|
///
|
|
|
|
odocstream & os_;
|
|
|
|
///
|
|
|
|
TexRow & 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 <typename Type>
|
|
|
|
otexrowstream & operator<<(otexrowstream & ots, Type value);
|
|
|
|
|
|
|
|
|
|
|
|
/** Subclass for otexrowstream.
|
|
|
|
This class is used to ensure that no blank lines may be inadvertently output.
|
2015-01-09 21:07:59 +01:00
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2015-10-07 04:02:40 +01:00
|
|
|
class otexstream : public otexrowstream {
|
2015-01-09 21:07:59 +01:00
|
|
|
public:
|
|
|
|
///
|
|
|
|
otexstream(odocstream & os, TexRow & texrow)
|
2015-10-07 04:02:40 +01:00
|
|
|
: otexrowstream(os, texrow), canbreakline_(false),
|
2015-01-09 21:07:59 +01:00
|
|
|
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 <typename Type>
|
|
|
|
otexstream & operator<<(otexstream & ots, Type value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|