From 7afb1fffefb1806205ddcef3cba1d2a559e9b39e Mon Sep 17 00:00:00 2001 From: Fridrich Štrba Date: Thu, 23 Aug 2012 14:13:49 +0200 Subject: Iterate the utf8 correctly + handle tabs too Change-Id: Ie6a4750ebd04e3b1ed8ad0985e141b6ff2e65e98 --- writerperfect/source/filter/OdgGenerator.cxx | 21 ++++++++++++++------- 1 file changed, 14 insertions(+), 7 deletions(-) (limited to 'writerperfect') diff --git a/writerperfect/source/filter/OdgGenerator.cxx b/writerperfect/source/filter/OdgGenerator.cxx index e8f365bda5eb..0d39862788f0 100644 --- a/writerperfect/source/filter/OdgGenerator.cxx +++ b/writerperfect/source/filter/OdgGenerator.cxx @@ -1750,12 +1750,11 @@ void OdgGenerator::endTextSpan() void OdgGenerator::insertText(const WPXString &text) { - int length = text.len(); WPXString out; - for (int curr = 0; curr < length; ++curr) + WPXString::Iter i(text); + for (i.rewind(); i.next();) { - char ch = text.cstr()[curr]; - if (ch == '\n') + if ((*i()) == '\n' || (*i()) == '\t') { if (out.len() != 0) { @@ -1763,12 +1762,20 @@ void OdgGenerator::insertText(const WPXString &text) mpImpl->mBodyElements.push_back(pText); out.clear(); } - mpImpl->mBodyElements.push_back(new TagOpenElement("text:line-break")); - mpImpl->mBodyElements.push_back(new TagCloseElement("text:line-break")); + if ((*i()) == '\n') + { + mpImpl->mBodyElements.push_back(new TagOpenElement("text:line-break")); + mpImpl->mBodyElements.push_back(new TagCloseElement("text:line-break")); + } + else if ((*i()) == '\t') + { + mpImpl->mBodyElements.push_back(new TagOpenElement("text:tab")); + mpImpl->mBodyElements.push_back(new TagCloseElement("text:tab")); + } } else { - out.append(ch); + out.append(i()); } } if (out.len() != 0) -- cgit