WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
16764
DOMRange doesn't correctly re-size when inserting items (Acid3)
https://bugs.webkit.org/show_bug.cgi?id=16764
Summary
DOMRange doesn't correctly re-size when inserting items (Acid3)
Andrew Wellington
Reported
2008-01-06 03:32:25 PST
(Follows on from
http://bugs.webkit.org/show_bug.cgi?id=16748
) // DOM Range function () { // test 11: basic ranges tests var r = document.createRange(); assert(r, "range not created"); assert(r.collapsed, "new range wasn't collapsed"); assert(r.commonAncestorContainer == document, "new range's common ancestor wasn't the document"); assert(r.startContainer == document, "new range's start container wasn't the document"); assert(r.startOffset == 0, "new range's start offset wasn't zero"); assert(r.endContainer == document, "new range's end container wasn't the document"); assert(r.endOffset == 0, "new range's end offset wasn't zero"); assert(r.cloneContents(), "cloneContents() didn't return an object"); assert(r.cloneContents().childNodes.length == 0, "nothing cloned was more than nothing"); assert(r.cloneRange().toString() == "", "nothing cloned stringifed to more than nothing"); r.collapse(true); // no effect assert(r.compareBoundaryPoints(r.START_TO_END, r.cloneRange()) == 0, "starting boundary point of range wasn't the same as the end boundary point of the clone range"); r.deleteContents(); // no effect assert(r.extractContents().childNodes.length == 0, "nothing removed was more than nothing"); r.insertNode(document.createComment("commented inserted to test ranges")); assert(!r.collapsed, "range with inserted comment isn't collapsed"); assert(r.commonAncestorContainer == document, "range with inserted comment has common ancestor that isn't the document"); assert(r.startContainer == document, "range with inserted comment has start container that isn't the document"); assert(r.startOffset == 0, "range with inserted comment has start offset that isn't zero"); assert(r.endContainer == document, "range with inserted comment has end container that isn't the document"); assert(r.endOffset == 1, "range with inserted comment has end offset that isn't after the comment"); return 1; }, Fails at: assert(!r.collapsed, "range with inserted comment isn't collapsed");
Attachments
Proposed patch
(8.50 KB, patch)
2008-01-06 04:31 PST
,
Andrew Wellington
no flags
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Andrew Wellington
Comment 1
2008-01-06 04:31:16 PST
Created
attachment 18299
[details]
Proposed patch Move the endOffset as required when new items are inserted.
Alexey Proskuryakov
Comment 2
2008-01-06 08:51:38 PST
I'm not sure that this is right approach - ranges should be fixed for any DOM mutations, not just those that happen to be made via DOMRange interface. See <
http://www.w3.org/TR/DOM-Level-2-Traversal-Range/ranges.html#Level-2-Range-Mutation
>.
Darin Adler
Comment 3
2008-01-06 11:23:31 PST
Comment on
attachment 18299
[details]
Proposed patch Usually a count would be named with a noun. The word "move" is more like a verb, so "offsetMove" is not a great variable name. Maybe offsetDelta or endOffsetAdjustment? + if (m_startContainer == m_endContainer) + m_endOffset += offsetMove; There's no if statement needed here -- you already ensured that the variable will be 0 in the case where the two are not equal. r=me
Darin Adler
Comment 4
2008-01-06 12:09:41 PST
(In reply to
comment #2
)
> I'm not sure that this is right approach - ranges should be fixed for any DOM > mutations, not just those that happen to be made via DOMRange interface. See > <
http://www.w3.org/TR/DOM-Level-2-Traversal-Range/ranges.html#Level-2-Range-Mutation
>.
I agree with Alexey. This approach is incorrect. However, I see no major harm in having this code which fixes only one particular case checked in, in the mean time. We can do the real fix later and remove this one special case -- the test case here will ensure we don't break this particular case.
Andrew Wellington
Comment 5
2008-01-06 14:39:00 PST
Comment on
attachment 18299
[details]
Proposed patch Landed in
r29214
I agree with Alexy on this, so I'll leave this bug open and clear the review flag on this patch.
Andrew Wellington
Comment 6
2008-01-06 17:54:59 PST
Calling this one fixed as I made a more general bug for this at
http://bugs.webkit.org/show_bug.cgi?id=16766
Lucas Forschler
Comment 7
2019-02-06 09:03:05 PST
Mass moving XML DOM bugs to the "DOM" Component.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug