Review Request: fix saving of textranges in KoTextWriter::Private::saveParagraph(...)

Friedrich W. H. Kossebau kossebau at kde.org
Thu Dec 6 14:11:47 GMT 2012


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
http://git.reviewboard.kde.org/r/107601/
-----------------------------------------------------------

(Updated Dec. 6, 2012, 2:11 p.m.)


Review request for Calligra and C. Boemann.


Changes
-------

Fixes:
* default lastEndPosition was 0, not block.position()
* loop over subspans possibly had 0-length subspans at start and end, resulting in garbage output
* more comments for loop over subspans hopefully explain things better


Description
-------

After lots of experiments here finally something relatively elegant (though you should have seen my intermediate hacks to understand ;) ).

Fixes the bugs seen with e.g. orpheus on saving bookmarks, at least for me. I think/hope I catched all cases which can be there by the parameters from & to, the possible textblock contents and the possible textranges.
Usage of KoTextRangeManager::textRangesChangingWithin(...) and KoTextRange::saveOdf(...) can be surely improved, but for now this here is at least a working fix.

Here my rationale for the patch:
Start and end tags of textranges can appear on positions in a text block.
in front of the first text element, between the elements, or behind the last.
A textblock is composed of no or many text fragments.
If there is no element at all, the only possible position is 0 (relative to the
begin of the block).
Start tags are ideally written in front of the content they are tagging,
and not behind the previous content. That way tags which are at the very begin
of the text do not need special handling.
End tags are ideally written directly behind the content, and not in front of
the next content. That way end tags which are at the very end of the text
do not need special handling.
Then there is the case of start tags which are at the final position of a text block:
the content they belong to includes the block end/border, so they need to be
written at the place of the last position.


Diffs (updated)
-----

  libs/kotext/KoAnnotation.h 0dfb43c 
  libs/kotext/KoAnnotation.cpp a700f02 
  libs/kotext/KoBookmark.h c64cbe1 
  libs/kotext/KoBookmark.cpp 5538e5f 
  libs/kotext/KoTextRange.h c728798 
  libs/kotext/opendocument/KoTextWriter_p.cpp 9cc353c 

Diff: http://git.reviewboard.kde.org/r/107601/diff/


Testing
-------

Oh yes. Created reports with lots of tables & charts, updated them, saved, updated, loaded, updated, added new tables & charts, updated, saved, updated, loaded, .... And no longer any issue then, so far.


Thanks,

Friedrich W. H. Kossebau

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/calligra-devel/attachments/20121206/576525d7/attachment.htm>


More information about the calligra-devel mailing list