0
Fork 0
mirror of https://github.com/fastmail/Squire.git synced 2024-12-31 11:54:03 -05:00

Fix bug in Range#insertTreeFragment

Merging containers could remove the nodeAfterSplit from the tree, which then
caused an error to be thrown if it had no content, as the code would try to
remove it again.
This commit is contained in:
Neil Jenkins 2013-01-30 11:30:11 +11:00
parent 775b72ec88
commit b35b7d4b35
2 changed files with 18 additions and 16 deletions

File diff suppressed because one or more lines are too long

View file

@ -1,6 +1,6 @@
/* Copyright © 2011-2012 by Neil Jenkins. Licensed under the MIT license. */ /* Copyright © 2011-2012 by Neil Jenkins. Licensed under the MIT license. */
/*global Range, Node, DOMTreeWalker */ /*global Range, DOMTreeWalker */
( function ( TreeWalker ) { ( function ( TreeWalker ) {
@ -268,30 +268,32 @@ var RangePrototypeExtensions = {
endOffset += 1; endOffset += 1;
} }
// Fix cursor before inserting block: // Fix cursor then insert block(s)
node = frag; node = frag;
while ( node = node.getNextBlock() ) { while ( node = node.getNextBlock() ) {
node.fixCursor(); node.fixCursor();
} }
parent.insertBefore( frag, nodeAfterSplit ); parent.insertBefore( frag, nodeAfterSplit );
// Merge containers at edges // Remove empty nodes created by split and merge inserted containers
nodeAfterSplit.mergeContainers(); // with edges of split
nodeBeforeSplit.nextSibling.mergeContainers(); node = nodeAfterSplit.previousSibling;
if ( !nodeAfterSplit.textContent ) {
// Remove empty nodes created by split.
if ( nodeAfterSplit === endContainer &&
!endContainer.textContent ) {
endContainer = endContainer.previousSibling;
endOffset = endContainer.getLength();
parent.removeChild( nodeAfterSplit ); parent.removeChild( nodeAfterSplit );
} else {
nodeAfterSplit.mergeContainers();
} }
if ( nodeBeforeSplit === startContainer && if ( !nodeAfterSplit.parentNode ) {
!startContainer.textContent) { endContainer = node;
startContainer = startContainer.nextSibling; endOffset = endContainer.getLength();
}
if ( !nodeBeforeSplit.textContent) {
startContainer = nodeBeforeSplit.nextSibling;
startOffset = 0; startOffset = 0;
parent.removeChild( nodeBeforeSplit ); parent.removeChild( nodeBeforeSplit );
} else {
nodeBeforeSplit.mergeContainers();
} }
this.setStart( startContainer, startOffset ); this.setStart( startContainer, startOffset );