Bug 12452

Summary: XPath id() function is not supported
Product: WebKit Reporter: Alexey Proskuryakov <ap>
Component: XMLAssignee: Alexey Proskuryakov <ap>
Status: RESOLVED FIXED    
Severity: Normal    
Priority: P2    
Version: 420+   
Hardware: Mac   
OS: OS X 10.4   
Bug Depends on:    
Bug Blocks: 12450    
Attachments:
Description Flags
implement id()
darin: review+
proposed fix darin: review+

Alexey Proskuryakov
Reported 2007-01-28 12:32:59 PST
See <http://www.w3.org/TR/xpath#function-id>. This causes a failure in "dom/svg/level3/xpath/Conformance_ID.svg".
Attachments
implement id() (7.08 KB, patch)
2007-01-30 10:48 PST, Alexey Proskuryakov
darin: review+
proposed fix (7.26 KB, patch)
2007-01-30 11:13 PST, Alexey Proskuryakov
darin: review+
Alexey Proskuryakov
Comment 1 2007-01-30 10:48:37 PST
Created attachment 12799 [details] implement id() I have certain doubts about XPathResult ordering. The existing code expects that it is each function's duty to preserve ordering, but that would be fairly inefficient when the client doesn't need ordered results. Maybe it would be better to re-order results in XPathResult::convertTo(). Similar issues arise for ANY_UNORDERED_NODE_TYPE, FIRST_ORDERED_NODE_TYPE and iterator types - building a full snapshot just to provide one of these is inefficient.
Alexey Proskuryakov
Comment 2 2007-01-30 10:51:58 PST
This patch doesn't implement one bit of id()-related functionality - this is the only function that returns a node-set, and the existing code doesn't expect that, thus paths including id() don't work. Going to file a follow-up bug.
Darin Adler
Comment 3 2007-01-30 10:52:56 PST
Comment on attachment 12799 [details] implement id() r=me I'm irritated to see yet-another isWhitespace function. I'd like to see us figure out which flavors of this we need and share central copies with easy-to-understand names. String is extremely inefficient to append to; it reallocates each time. So a loop that appends the string value and then a space is O(n^2) the size of the string. The way to avoid this is to use a Vector<UChar> instead, and convert to a String at the end with String::adopt.
Alexey Proskuryakov
Comment 4 2007-01-30 11:13:45 PST
Created attachment 12801 [details] proposed fix > I'm irritated to see yet-another isWhitespace function. There was a single identical one I could find, in SVGParserUtilities.h. I believe parts of this file should be abstracted out, because they have nothing to do with SVG. > String is extremely inefficient to append to; it reallocates each time. I allowed myself this sloppiness, because I couldn't see how this would noticeably slow down XPath -but OK.
Darin Adler
Comment 5 2007-01-30 11:17:31 PST
Comment on attachment 12801 [details] proposed fix This one looks good too! r=me
Alexey Proskuryakov
Comment 6 2007-01-30 11:21:42 PST
Committed revision 19263.
Note You need to log in before you can comment on or make changes to this bug.