From d7c3ab3203c55dc63f4b057ae9cfd1f4a190f4e1 Mon Sep 17 00:00:00 2001 From: Abdelrazak Younes Date: Wed, 24 Oct 2007 07:08:55 +0000 Subject: [PATCH] * Paragraph: Move more things to Paragraph::Private - remove META_INSET from Paragraph.h - move text_ container to Private. I know this put there for performance reason but I don't see any penalty with this move. I guess this is because Buffer loading doesn't use Paragraph::getChar() anymore. I will move performance critical code to Paragraph::Private when/if we detect them. - replace Paragraph::value_type with straight char_type: this was more noise than anything. git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@21163 a592a061-630c-0410-9148-cb99ea01b6c8 --- src/CutAndPaste.cpp | 2 +- src/Paragraph.cpp | 171 +++++++++++++++----------- src/Paragraph.h | 46 ++----- src/ParagraphMetrics.cpp | 6 +- src/Text.cpp | 3 +- src/frontends/qt4/GuiSpellchecker.cpp | 3 +- src/output_plaintext.cpp | 8 +- src/paragraph_funcs.cpp | 4 +- 8 files changed, 122 insertions(+), 121 deletions(-) diff --git a/src/CutAndPaste.cpp b/src/CutAndPaste.cpp index 93fb67c1ea..3692dcc873 100644 --- a/src/CutAndPaste.cpp +++ b/src/CutAndPaste.cpp @@ -196,7 +196,7 @@ pasteSelectionHelper(Cursor & cur, ParagraphList const & parlist, // Set the inset owner of this paragraph. tmpbuf->setInsetOwner(pars[pit].inInset()); for (pos_type i = 0; i < tmpbuf->size(); ++i) { - if (tmpbuf->getChar(i) == Paragraph::META_INSET && + if (tmpbuf->isInset(i) && !pars[pit].insetAllowed(tmpbuf->getInset(i)->lyxCode())) // do not track deletion of invalid insets tmpbuf->eraseChar(i--, false); diff --git a/src/Paragraph.cpp b/src/Paragraph.cpp index bd368ef6c5..21b02b8a50 100644 --- a/src/Paragraph.cpp +++ b/src/Paragraph.cpp @@ -57,6 +57,7 @@ #include "support/unicode.h" #include +#include using std::endl; using std::string; @@ -70,6 +71,10 @@ using support::suffixIs; using support::rsplit; using support::rtrim; +namespace { +/// Inset identifier (above 0x10ffff, for ucs-4) +char_type const META_INSET = 0x200001; +}; ///////////////////////////////////////////////////////////////////// // @@ -86,13 +91,11 @@ public: Private(Private const &, Paragraph * owner); /// - value_type getChar(pos_type pos) const; - /// - void insertChar(pos_type pos, value_type c, Change const & change); + void insertChar(pos_type pos, char_type c, Change const & change); /// Output the surrogate pair formed by \p c and \p next to \p os. /// \return the number of characters written. - int latexSurrogatePair(odocstream & os, value_type c, value_type next, + int latexSurrogatePair(odocstream & os, char_type c, char_type next, Encoding const &); /// Output a space in appropriate formatting (or a surrogate pair @@ -108,7 +111,7 @@ public: /// Output consecutive known unicode chars, belonging to the same /// language as specified by \p preamble, to \p os starting from \p c. /// \return the number of characters written. - int knownLangChars(odocstream & os, value_type c, string & preamble, + int knownLangChars(odocstream & os, char_type c, string & preamble, Change &, Encoding const &, pos_type &); /// This could go to ParagraphParameters if we want to. @@ -197,6 +200,10 @@ public: /// end of label pos_type begin_of_body_; + + typedef std::vector TextContainer; + /// + TextContainer text_; }; @@ -235,13 +242,14 @@ Paragraph::Private::Private(Paragraph * owner) : owner_(owner), inset_owner_(0), begin_of_body_(0) { id_ = paragraph_id++; + text_.reserve(100); } Paragraph::Private::Private(Private const & p, Paragraph * owner) : owner_(owner), inset_owner_(p.inset_owner_), fontlist_(p.fontlist_), params_(p.params_), changes_(p.changes_), insetlist_(p.insetlist_), - layout_(p.layout_), begin_of_body_(p.begin_of_body_) + layout_(p.layout_), begin_of_body_(p.begin_of_body_), text_(p.text_) { id_ = paragraph_id++; } @@ -393,15 +401,7 @@ void Paragraph::rejectChanges(BufferParams const & bparams, } -Paragraph::value_type Paragraph::Private::getChar(pos_type pos) const -{ - BOOST_ASSERT(pos >= 0 && pos <= size()); - - return owner_->getChar(pos); -} - - -void Paragraph::Private::insertChar(pos_type pos, value_type c, +void Paragraph::Private::insertChar(pos_type pos, char_type c, Change const & change) { BOOST_ASSERT(pos >= 0 && pos <= size()); @@ -413,11 +413,11 @@ void Paragraph::Private::insertChar(pos_type pos, value_type c, // maybe inserting ascii text) if (pos == size()) { // when appending characters, no need to update tables - owner_->text_.push_back(c); + text_.push_back(c); return; } - owner_->text_.insert(owner_->text_.begin() + pos, c); + text_.insert(text_.begin() + pos, c); // Update the font table. fontlist_.increasePosAfterPos(pos); @@ -434,7 +434,7 @@ void Paragraph::insertInset(pos_type pos, Inset * inset, BOOST_ASSERT(pos >= 0 && pos <= size()); d->insertChar(pos, META_INSET, change); - BOOST_ASSERT(text_[pos] == META_INSET); + BOOST_ASSERT(d->text_[pos] == META_INSET); // Add a new entry in the insetlist_. d->insetlist_.insert(inset, pos); @@ -475,10 +475,10 @@ bool Paragraph::eraseChar(pos_type pos, bool trackChanges) d->changes_.erase(pos); // if it is an inset, delete the inset entry - if (text_[pos] == Paragraph::META_INSET) + if (d->text_[pos] == META_INSET) d->insetlist_.erase(pos); - text_.erase(text_.begin() + pos); + d->text_.erase(d->text_.begin() + pos); // Update the fontlist_ d->fontlist_.erase(pos); @@ -504,8 +504,8 @@ int Paragraph::eraseChars(pos_type start, pos_type end, bool trackChanges) } -int Paragraph::Private::latexSurrogatePair(odocstream & os, value_type c, - value_type next, Encoding const & encoding) +int Paragraph::Private::latexSurrogatePair(odocstream & os, char_type c, + char_type next, Encoding const & encoding) { // Writing next here may circumvent a possible font change between // c and next. Since next is only output if it forms a surrogate pair @@ -532,7 +532,7 @@ bool Paragraph::Private::simpleTeXBlanks(Encoding const & encoding, return false; if (i + 1 < size()) { - char_type next = getChar(i + 1); + char_type next = text_[i + 1]; if (Encodings::isCombiningChar(next)) { // This space has an accent, so we must always output it. column += latexSurrogatePair(os, ' ', next, encoding) - 1; @@ -543,17 +543,17 @@ bool Paragraph::Private::simpleTeXBlanks(Encoding const & encoding, if (lyxrc.plaintext_linelen > 0 && column > lyxrc.plaintext_linelen && i - && getChar(i - 1) != ' ' + && text_[i - 1] != ' ' && (i + 1 < size()) // same in FreeSpacing mode && !owner_->isFreeSpacing() // In typewriter mode, we want to avoid // ! . ? : at the end of a line && !(font.family() == Font::TYPEWRITER_FAMILY - && (getChar(i - 1) == '.' - || getChar(i - 1) == '?' - || getChar(i - 1) == ':' - || getChar(i - 1) == '!'))) { + && (text_[i - 1] == '.' + || text_[i - 1] == '?' + || text_[i - 1] == ':' + || text_[i - 1] == '!'))) { os << '\n'; texrow.newline(); texrow.start(owner_->id(), i + 1); @@ -568,7 +568,7 @@ bool Paragraph::Private::simpleTeXBlanks(Encoding const & encoding, int Paragraph::Private::knownLangChars(odocstream & os, - value_type c, + char_type c, string & preamble, Change & runningChange, Encoding const & encoding, @@ -584,7 +584,7 @@ int Paragraph::Private::knownLangChars(odocstream & os, int length = latex1.length(); os << latex1; while (i + 1 < size()) { - char_type next = getChar(i + 1); + char_type next = text_[i + 1]; // Stop here if next character belongs to another // language or there is a change tracking status. if (!Encodings::isKnownLangChar(next, preamble) || @@ -639,7 +639,7 @@ bool Paragraph::Private::isTextAt(string const & str, pos_type pos) const for (string::size_type i = 0; i < str.length(); ++i) { // Caution: direct comparison of characters works only // because str is pure ASCII. - if (str[i] != owner_->text_[pos + i]) + if (str[i] != text_[pos + i]) return false; } @@ -792,7 +792,7 @@ void Paragraph::Private::latexSpecialChar( pos_type & i, unsigned int & column) { - value_type const c = getChar(i); + char_type const c = text_[i]; if (style.pass_thru) { if (c != '\0') @@ -885,7 +885,7 @@ void Paragraph::Private::latexSpecialChar( Encoding const & encoding = *(runparams.encoding); if (i + 1 < size()) { - char_type next = getChar(i + 1); + char_type next = text_[i + 1]; if (Encodings::isCombiningChar(next)) { column += latexSurrogatePair(os, c, next, encoding) - 1; ++i; @@ -923,7 +923,7 @@ bool Paragraph::Private::latexSpecialT1(char_type const c, odocstream & os, os.put(c); // In T1 encoding, these characters exist // but we should avoid ligatures - if (i + 1 > size() || getChar(i + 1) != c) + if (i + 1 > size() || text_[i + 1] != c) return true; os << "\\,{}"; column += 3; @@ -945,7 +945,7 @@ bool Paragraph::Private::latexSpecialTypewriter(char_type const c, odocstream & { switch (c) { case '-': - if (i + 1 < size() && getChar(i + 1) == '-') { + if (i + 1 < size() && text_[i + 1] == '-') { // "--" in Typewriter mode -> "-{}-" os << "-{}"; column += 2; @@ -1039,7 +1039,7 @@ void Paragraph::Private::validate(LaTeXFeatures & features, break; } } - Encodings::validate(getChar(i), features); + Encodings::validate(text_[i], features); } } @@ -1054,12 +1054,11 @@ Paragraph::Paragraph() { itemdepth = 0; d->params_.clear(); - text_.reserve(100); } Paragraph::Paragraph(Paragraph const & par) - : itemdepth(par.itemdepth), text_(par.text_), + : itemdepth(par.itemdepth), d(new Paragraph::Private(*par.d, this)) { } @@ -1070,7 +1069,6 @@ Paragraph & Paragraph::operator=(Paragraph const & par) // needed as we will destroy the private part before copying it if (&par != this) { itemdepth = par.itemdepth; - text_ = par.text_; delete d; d = new Private(*par.d, this); @@ -1131,7 +1129,7 @@ void Paragraph::write(Buffer const & buf, ostream & os, font1 = font2; } - value_type const c = getChar(i); + char_type const c = d->text_[i]; switch (c) { case META_INSET: { @@ -1157,7 +1155,7 @@ void Paragraph::write(Buffer const & buf, ostream & os, column = 0; break; case '.': - if (i + 1 < size() && getChar(i + 1) == ' ') { + if (i + 1 < size() && d->text_[i + 1] == ' ') { os << ".\n"; column = 0; } else @@ -1201,14 +1199,14 @@ void Paragraph::insert(pos_type start, docstring const & str, } -void Paragraph::appendChar(value_type c, Font const & font, +void Paragraph::appendChar(char_type c, Font const & font, Change const & change) { // track change - d->changes_.insert(change, text_.size()); + d->changes_.insert(change, d->text_.size()); // when appending characters, no need to update tables - text_.push_back(c); - setFont(text_.size() - 1, font); + d->text_.push_back(c); + setFont(d->text_.size() - 1, font); } @@ -1216,24 +1214,24 @@ void Paragraph::appendString(docstring const & s, Font const & font, Change const & change) { size_t end = s.size(); - size_t oldsize = text_.size(); + size_t oldsize = d->text_.size(); size_t newsize = oldsize + end; - size_t capacity = text_.capacity(); + size_t capacity = d->text_.capacity(); if (newsize >= capacity) - text_.reserve(std::max(capacity + 100, newsize)); + d->text_.reserve(std::max(capacity + 100, newsize)); // FIXME: Optimize this! for (pos_type i = 0; i != end; ++i) { // track change d->changes_.insert(change, i); // when appending characters, no need to update tables - text_.push_back(s[i]); + d->text_.push_back(s[i]); } d->fontlist_.setRange(oldsize, newsize, font); } -void Paragraph::insertChar(pos_type pos, Paragraph::value_type c, +void Paragraph::insertChar(pos_type pos, char_type c, bool trackChanges) { d->insertChar(pos, c, Change(trackChanges ? @@ -1241,7 +1239,7 @@ void Paragraph::insertChar(pos_type pos, Paragraph::value_type c, } -void Paragraph::insertChar(pos_type pos, Paragraph::value_type c, +void Paragraph::insertChar(pos_type pos, char_type c, Font const & font, bool trackChanges) { d->insertChar(pos, c, Change(trackChanges ? @@ -1250,7 +1248,7 @@ void Paragraph::insertChar(pos_type pos, Paragraph::value_type c, } -void Paragraph::insertChar(pos_type pos, Paragraph::value_type c, +void Paragraph::insertChar(pos_type pos, char_type c, Font const & font, Change const & change) { d->insertChar(pos, c, change); @@ -1385,14 +1383,14 @@ Font_size Paragraph::highestFontInRange } -Paragraph::value_type +char_type Paragraph::getUChar(BufferParams const & bparams, pos_type pos) const { - value_type c = getChar(pos); + char_type c = d->text_[pos]; if (!lyxrc.rtl_support) return c; - value_type uc = c; + char_type uc = c; switch (c) { case '(': uc = ')'; @@ -1603,11 +1601,11 @@ void Paragraph::setBeginOfBody() char_type previous_char = 0; char_type temp = 0; if (i < end) { - previous_char = text_[i]; + previous_char = d->text_[i]; if (!isNewline(i)) { ++i; while (i < end && previous_char != ' ') { - temp = text_[i]; + temp = d->text_[i]; if (isNewline(i)) break; ++i; @@ -1971,7 +1969,7 @@ bool Paragraph::latex(Buffer const & buf, } } - value_type const c = getChar(i); + char_type const c = d->text_[i]; // Do we need to change font? if ((font != running_font || @@ -2022,7 +2020,7 @@ bool Paragraph::latex(Buffer const & buf, // Two major modes: LaTeX or plain // Handle here those cases common to both modes // and then split to handle the two modes separately. - if (c == Paragraph::META_INSET) + if (c == META_INSET) d->latexInset(buf, bparams, os, texrow, rp, running_font, basefont, outerfont, open_font, @@ -2134,7 +2132,7 @@ bool Paragraph::emptyTag() const return false; } } else { - value_type c = getChar(i); + char_type c = d->text_[i]; if (c != ' ' && c != '\t') return false; } @@ -2169,7 +2167,7 @@ pos_type Paragraph::getFirstWord(Buffer const & buf, odocstream & os, OutputPara Inset const * inset = getInset(i); inset->docbook(buf, os, runparams); } else { - value_type c = getChar(i); + char_type c = d->text_[i]; if (c == ' ') break; os << sgml::escapeChar(c); @@ -2230,7 +2228,7 @@ void Paragraph::simpleDocBookOnePar(Buffer const & buf, Inset const * inset = getInset(i); inset->docbook(buf, os, runparams); } else { - value_type c = getChar(i); + char_type c = d->text_[i]; if (style->pass_thru) os.put(c); @@ -2267,9 +2265,9 @@ bool Paragraph::isNewline(pos_type pos) const bool Paragraph::isLineSeparator(pos_type pos) const { - value_type const c = getChar(pos); + char_type const c = d->text_[pos]; return isLineSeparatorChar(c) - || (c == Paragraph::META_INSET && getInset(pos) && + || (c == META_INSET && getInset(pos) && getInset(pos)->isLineSeparator()); } @@ -2280,7 +2278,7 @@ bool Paragraph::isLetter(pos_type pos) const if (isInset(pos)) return getInset(pos)->isLetter(); else { - value_type const c = getChar(pos); + char_type const c = d->text_[pos]; return isLetterChar(c) || isDigit(c); } } @@ -2352,7 +2350,7 @@ docstring const Paragraph::asString(Buffer const & buffer, os << params().labelString() << ' '; for (pos_type i = beg; i < end; ++i) { - value_type const c = getChar(i); + char_type const c = d->text_[i]; if (isPrintable(c)) os.put(c); else if (c == META_INSET) @@ -2436,11 +2434,11 @@ char_type Paragraph::transformChar(char_type c, pos_type pos) const if (!Encodings::is_arabic(c)) return c; - value_type prev_char = ' '; - value_type next_char = ' '; + char_type prev_char = ' '; + char_type next_char = ' '; for (pos_type i = pos - 1; i >= 0; --i) { - value_type const par_char = getChar(i); + char_type const par_char = d->text_[i]; if (!Encodings::isComposeChar_arabic(par_char)) { prev_char = par_char; break; @@ -2448,7 +2446,7 @@ char_type Paragraph::transformChar(char_type c, pos_type pos) const } for (pos_type i = pos + 1, end = size(); i < end; ++i) { - value_type const par_char = getChar(i); + char_type const par_char = d->text_[i]; if (!Encodings::isComposeChar_arabic(par_char)) { next_char = par_char; break; @@ -2483,7 +2481,7 @@ int Paragraph::checkBiblio(bool track_changes) bool hasbibitem = !d->insetlist_.empty() // Insist on it being in pos 0 - && getChar(0) == Paragraph::META_INSET + && d->text_[0] == META_INSET && d->insetlist_.begin()->inset->lyxCode() == BIBITEM_CODE; docstring oldkey; @@ -2602,4 +2600,35 @@ int Paragraph::numberOfOptArgs() const } +char_type Paragraph::getChar(pos_type pos) const +{ + return d->text_[pos]; +} + + +pos_type Paragraph::size() const +{ + return d->text_.size(); +} + + +bool Paragraph::empty() const +{ + return d->text_.empty(); +} + + +bool Paragraph::isInset(pos_type pos) const +{ + return d->text_[pos] == META_INSET; +} + + +bool Paragraph::isSeparator(pos_type pos) const +{ + //FIXME: Are we sure this can be the only separator? + return d->text_[pos] == ' '; +} + + } // namespace lyx diff --git a/src/Paragraph.h b/src/Paragraph.h index b46960784e..7e206deffe 100644 --- a/src/Paragraph.h +++ b/src/Paragraph.h @@ -25,8 +25,6 @@ // including this: #include "support/docstream.h" -#include - namespace lyx { class AuthorList; @@ -67,19 +65,6 @@ public: /// should go in order to complete the Model/View separation of this class. class Paragraph { public: - /// - enum { - /// Note that this is 1 right now to avoid - /// crashes where getChar() is called wrongly - /// (returning 0) - if this was 0, then we'd - /// try getInset() and crash. We should fix - /// all these places. - //META_INSET = 1 // as in trunk - META_INSET = 0x200001 // above 0x10ffff, for ucs-4 - }; - /// - typedef char_type value_type; - /// Paragraph(); /// @@ -159,9 +144,9 @@ public: bool forceDefaultParagraphs() const; /// - pos_type size() const { return text_.size(); } + pos_type size() const; /// - bool empty() const { return text_.empty(); } + bool empty() const; /// LayoutPtr const & layout() const; @@ -268,10 +253,9 @@ public: */ FontSpan fontSpan(pos_type pos) const; /// - /// this is a bottleneck. - value_type getChar(pos_type pos) const { return text_[pos]; } + char_type getChar(pos_type pos) const; /// Get the char, but mirror all bracket characters if it is right-to-left - value_type getUChar(BufferParams const &, pos_type pos) const; + char_type getUChar(BufferParams const &, pos_type pos) const; /// pos <= size() (there is a dummy font change at the end of each par) void setFont(pos_type pos, Font const & font); /// Returns the height of the highest font in range @@ -285,14 +269,14 @@ public: void appendString(docstring const & s, Font const & font, Change const & change); /// - void appendChar(value_type c, Font const & font, Change const & change); + void appendChar(char_type c, Font const & font, Change const & change); /// - void insertChar(pos_type pos, value_type c, bool trackChanges); + void insertChar(pos_type pos, char_type c, bool trackChanges); /// - void insertChar(pos_type pos, value_type c, + void insertChar(pos_type pos, char_type c, Font const &, bool trackChanges); /// - void insertChar(pos_type pos, value_type c, + void insertChar(pos_type pos, char_type c, Font const &, Change const & change); /// void insertInset(pos_type pos, Inset * inset, @@ -320,13 +304,11 @@ public: bool isHfill(pos_type pos) const; /// hinted by profiler - bool isInset(pos_type pos) const { - return getChar(pos) == static_cast(META_INSET); - } + bool isInset(pos_type pos) const; /// bool isNewline(pos_type pos) const; /// return true if the char is a word separator - bool isSeparator(pos_type pos) const { return getChar(pos) == ' '; } + bool isSeparator(pos_type pos) const; /// bool isLineSeparator(pos_type pos) const; /// True if the character/inset at this point can be part of a word. @@ -366,14 +348,6 @@ public: int numberOfOptArgs() const; private: - /** - * Keeping this here instead of in the pimpl makes LyX >10% faster - * for average tasks as buffer loading/switching etc. - */ - typedef std::vector TextContainer; - /// - TextContainer text_; - /// Pimpl away stuff class Private; /// diff --git a/src/ParagraphMetrics.cpp b/src/ParagraphMetrics.cpp index 6b88908308..02eb591ff7 100644 --- a/src/ParagraphMetrics.cpp +++ b/src/ParagraphMetrics.cpp @@ -215,12 +215,12 @@ int ParagraphMetrics::rightMargin(Buffer const & buffer) const int ParagraphMetrics::singleWidth(pos_type pos, Font const & font) const { - char_type c = par_->getChar(pos); - // The most special cases are handled first. - if (c == Paragraph::META_INSET) + if (par_->isInset(pos);) return insetDimension(par_->getInset(pos)).wid; + char_type c = par_->getChar(pos); + if (!isPrintable(c)) return theFontMetrics(font).width(c); diff --git a/src/Text.cpp b/src/Text.cpp index 67c60affb0..d7b0355338 100644 --- a/src/Text.cpp +++ b/src/Text.cpp @@ -428,7 +428,6 @@ void Text::breakParagraph(Cursor & cur, bool inverse_logic) void Text::insertChar(Cursor & cur, char_type c) { BOOST_ASSERT(this == cur.text()); - BOOST_ASSERT(c != Paragraph::META_INSET); cur.recordUndo(INSERT_UNDO); @@ -873,7 +872,7 @@ void Text::changeCase(Cursor & cur, Text::TextCase action) char_type newChar = oldChar; // ignore insets and don't play with deleted text! - if (oldChar != Paragraph::META_INSET && !pars_[pit].isDeleted(pos)) { + if (pars_[pit].isInset(pos) && !pars_[pit].isDeleted(pos)) { switch (action) { case text_lowercase: newChar = lowercase(oldChar); diff --git a/src/frontends/qt4/GuiSpellchecker.cpp b/src/frontends/qt4/GuiSpellchecker.cpp index e3755236f0..c44a598ded 100644 --- a/src/frontends/qt4/GuiSpellchecker.cpp +++ b/src/frontends/qt4/GuiSpellchecker.cpp @@ -294,8 +294,7 @@ static WordLangTuple nextWord(Cursor & cur, ptrdiff_t & progress) // Insets like optional hyphens and ligature // break are part of a word. if (!cur.paragraph().isInset(cur.pos())) { - Paragraph::value_type const c = - cur.paragraph().getChar(cur.pos()); + char_type const c = cur.paragraph().getChar(cur.pos()); word += c; if (isDigit(c)) ignoreword = true; diff --git a/src/output_plaintext.cpp b/src/output_plaintext.cpp index 39c5f1a134..7f37f8d70c 100644 --- a/src/output_plaintext.cpp +++ b/src/output_plaintext.cpp @@ -192,7 +192,7 @@ void writePlaintextParagraph(Buffer const & buf, char_type c = par.getUChar(buf.params(), i); - if (c == Paragraph::META_INSET || c == ' ') { + if (par.isInset(i) || c == ' ') { if (runparams.linelen > 0 && currlinelen + word.length() > runparams.linelen) { os << '\n'; @@ -205,8 +205,7 @@ void writePlaintextParagraph(Buffer const & buf, word.erase(); } - switch (c) { - case Paragraph::META_INSET: { + if (par.isInset(i)) { OutputParams rp = runparams; rp.depth = par.params().depth(); int len = par.getInset(i)->plaintext(buf, os, rp); @@ -214,9 +213,10 @@ void writePlaintextParagraph(Buffer const & buf, currlinelen = len - Inset::PLAINTEXT_NEWLINE; else currlinelen += len; - break; + continue; } + switch (c) { case ' ': os << ' '; currlinelen++; diff --git a/src/paragraph_funcs.cpp b/src/paragraph_funcs.cpp index 0dbacb46ac..367f214a1c 100644 --- a/src/paragraph_funcs.cpp +++ b/src/paragraph_funcs.cpp @@ -35,11 +35,11 @@ static bool moveItem(Paragraph & fromPar, pos_type fromPos, // Note: moveItem() does not honour change tracking! // Therefore, it should only be used for breaking and merging paragraphs - Paragraph::value_type const tmpChar = fromPar.getChar(fromPos); + char_type const tmpChar = fromPar.getChar(fromPos); Font const tmpFont = fromPar.getFontSettings(params, fromPos); Change const tmpChange = fromPar.lookupChange(fromPos); - if (tmpChar == Paragraph::META_INSET) { + if (fromPar.isInset(fromPos)) { Inset * tmpInset = 0; if (fromPar.getInset(fromPos)) { // the inset is not in the paragraph any more