X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=src%2Foutput_plaintext.cpp;h=b0450bda9f3a731d68b19e8953f183e996cba7b7;hb=3b30dbfca4936adac9a6eb94fced33d36e617734;hp=f0a383df4c02591c6afb0851f0cfc8873d1021ff;hpb=6b2232a29c682d8e62d1d2b963bb1a70bee4330b;p=features.git diff --git a/src/output_plaintext.cpp b/src/output_plaintext.cpp index f0a383df4c..b0450bda9f 100644 --- a/src/output_plaintext.cpp +++ b/src/output_plaintext.cpp @@ -21,6 +21,8 @@ #include "ParagraphList.h" #include "ParagraphParameters.h" +#include "insets/Inset.h" + #include "support/debug.h" #include "support/gettext.h" #include "support/lstrings.h" @@ -41,6 +43,7 @@ void writePlaintextFile(Buffer const & buf, FileName const & fname, // make sure we are ready to export buf.updateBuffer(); buf.updateMacroInstances(OutputUpdate); + buf.makeCitationLabels(); writePlaintextFile(buf, ofs, runparams); } @@ -55,9 +58,11 @@ void writePlaintextFile(Buffer const & buf, odocstream & os, ParagraphList::const_iterator end = par.end(); ParagraphList::const_iterator it = beg; for (; it != end; ++it) { + bool const merged_par = (*it).parEndChange().deleted(); writePlaintextParagraph(buf, *it, os, runparams, ref_printed); - os << "\n"; - if (runparams.linelen > 0) + if (!merged_par) + os << "\n"; + if (runparams.linelen > 0 && !merged_par) os << "\n"; } } @@ -74,9 +79,9 @@ static pair addDepth(int depth, int ldepth) void writePlaintextParagraph(Buffer const & buf, Paragraph const & par, - odocstream & os, + odocstream & ods, OutputParams const & runparams, - bool & ref_printed) + bool & ref_printed, size_t max_length) { int ltype = 0; depth_type ltype_depth = 0; @@ -120,6 +125,7 @@ void writePlaintextParagraph(Buffer const & buf, string::size_type currlinelen = 0; + odocstringstream os; os << docstring(depth * 2, ' '); currlinelen += depth * 2; @@ -183,7 +189,10 @@ void writePlaintextParagraph(Buffer const & buf, if (par.isDeleted(i)) continue; - char_type c = par.getUChar(buf.params(), i); + if (os.str().size() > max_length) + break; + + char_type c = par.getUChar(buf.params(), runparams, i); if (par.isInset(i) || c == ' ') { if (runparams.linelen > 0 && @@ -201,7 +210,7 @@ void writePlaintextParagraph(Buffer const & buf, if (par.isInset(i)) { OutputParams rp = runparams; rp.depth = par.params().depth(); - int len = par.getInset(i)->plaintext(os, rp); + int len = par.getInset(i)->plaintext(os, rp, max_length); if (len >= Inset::PLAINTEXT_NEWLINE) currlinelen = len - Inset::PLAINTEXT_NEWLINE; else @@ -212,7 +221,7 @@ void writePlaintextParagraph(Buffer const & buf, switch (c) { case ' ': os << ' '; - currlinelen++; + ++currlinelen; break; case '\0': @@ -237,6 +246,7 @@ void writePlaintextParagraph(Buffer const & buf, } os << word; } + ods << os.str(); }