protectspace_ = false;
}
os_.put(c);
- lastchar_ = c;
- if (c == '\n') {
+ lastChar(c);
+ if (c == '\n')
texrow_.newline();
- canbreakline_ = false;
- } else
- canbreakline_ = true;
}
if (ots.canBreakLine()) {
ots.os().put('\n');
ots.lastChar('\n');
- ots.canBreakLine(false);
ots.texrow().newline();
}
ots.protectSpace(false);
if (ots.canBreakLine()) {
ots.os() << "%\n";
ots.lastChar('\n');
- ots.canBreakLine(false);
ots.texrow().newline();
}
ots.protectSpace(false);
} else
ots.os() << s;
+ if (len > 1)
+ ots.canBreakLine(s[len - 2] != '\n');
ots.lastChar(s[len - 1]);
ots.texrow().newlines(count(s.begin(), s.end(), '\n'));
- ots.canBreakLine(s[len - 1] != '\n');
return ots;
}
ots.lastChar(c);
if (c == '\n')
ots.texrow().newline();
- ots.canBreakLine(c != '\n');
return ots;
}
{
ots.os() << value;
ots.lastChar(0);
- ots.canBreakLine(true);
ots.protectSpace(false);
return ots;
}
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.
+ The class also records the last output character and can tell whether
+ a paragraph break was just output.
*/
class otexstream {
public:
///
otexstream(odocstream & os, TexRow & texrow)
- : os_(os), texrow_(texrow),
- canbreakline_(false), protectspace_(false), lastchar_(0) {}
+ : os_(os), texrow_(texrow), canbreakline_(false),
+ protectspace_(false), parbreak_(true), lastchar_(0) {}
///
odocstream & os() { return os_; }
///
///
bool protectSpace() const { return protectspace_; }
///
- void lastChar(char_type const & c) { lastchar_ = c; }
+ 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:
///
odocstream & os_;
///
bool protectspace_;
///
+ bool parbreak_;
+ ///
char_type lastchar_;
};