Bug 46367

Summary: CSSParser: Enable rule selector source range extraction
Product: WebKit Reporter: Alexander Pavlov (apavlov) <apavlov>
Component: CSSAssignee: Alexander Pavlov (apavlov) <apavlov>
Status: RESOLVED FIXED    
Severity: Normal CC: annevk, bweinstein, eric, hyatt, joepeck, keishi, loislo, mitz, pfeldman, pmuellr, rik, sam, timothy, webkit-ews, webkit.review.bot, yurys
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Bug Depends on:    
Bug Blocks: 45825    
Attachments:
Description Flags
[PATCH] Suggested solution
none
[PATCH] Style fixed
none
[PATCH] Do not return an ExceptionCode in the event of an error in setSelectorText()
sam: review-
[PATCH] Only source offsets extraction for rule selectors
none
[PATCH] Fix selector list end detection
none
[PATCH] Rebase + small API change
none
[PATCH] Rebase for compilability
pfeldman: review-
[PATCH] Comment addressed pfeldman: review+

Alexander Pavlov (apavlov)
Reported 2010-09-23 10:08:52 PDT
CSSStyleRule::setSelectorText() is currently not implemented but is beneficial at least for changing rule selectors via the Web Inspector. Selector source range extraction is needed for the text-based CSS editing.
Attachments
[PATCH] Suggested solution (12.08 KB, patch)
2010-09-23 10:31 PDT, Alexander Pavlov (apavlov)
no flags
[PATCH] Style fixed (12.04 KB, patch)
2010-09-23 10:37 PDT, Alexander Pavlov (apavlov)
no flags
[PATCH] Do not return an ExceptionCode in the event of an error in setSelectorText() (11.97 KB, patch)
2010-09-24 01:56 PDT, Alexander Pavlov (apavlov)
sam: review-
[PATCH] Only source offsets extraction for rule selectors (10.30 KB, patch)
2010-09-27 09:19 PDT, Alexander Pavlov (apavlov)
no flags
[PATCH] Fix selector list end detection (10.27 KB, patch)
2010-09-28 01:29 PDT, Alexander Pavlov (apavlov)
no flags
[PATCH] Rebase + small API change (18.96 KB, patch)
2010-10-05 09:07 PDT, Alexander Pavlov (apavlov)
no flags
[PATCH] Rebase for compilability (18.96 KB, patch)
2010-10-05 10:14 PDT, Alexander Pavlov (apavlov)
pfeldman: review-
[PATCH] Comment addressed (22.08 KB, patch)
2010-10-06 07:31 PDT, Alexander Pavlov (apavlov)
pfeldman: review+
Alexander Pavlov (apavlov)
Comment 1 2010-09-23 10:29:25 PDT
One thing I am unsure about is the ExceptionCodes I should return from setSelectorText for when there is no document associated with the CSSStyleRule being processed (which CSSParser needs to parse the selector) and there is an error parsing the selector. None of the w3c documents seem to cover this issue. I have chosen the semantically similar WRONG_DOCUMENT_ERR and SYNTAX_ERR, but there may be another opinion.
Alexander Pavlov (apavlov)
Comment 2 2010-09-23 10:31:41 PDT
Created attachment 68541 [details] [PATCH] Suggested solution
WebKit Review Bot
Comment 3 2010-09-23 10:33:39 PDT
Attachment 68541 [details] did not pass style-queue: Failed to run "['WebKitTools/Scripts/check-webkit-style']" exit_code: 1 WebCore/css/CSSParser.cpp:5750: A case label should not be indented, but line up with its switch statement. [whitespace/indent] [4] Total errors found: 1 in 6 files If any of these errors are false positives, please file a bug against check-webkit-style.
Alexander Pavlov (apavlov)
Comment 4 2010-09-23 10:37:22 PDT
Created attachment 68544 [details] [PATCH] Style fixed
Anne van Kesteren
Comment 5 2010-09-23 23:33:43 PDT
Actually, per http://dev.w3.org/csswg/cssom/ you should not throw a SYNTAX_ERR (just ignore it). I'm not sure how you can get a CSSStyleRule separately from a style sheet.
Alexander Pavlov (apavlov)
Comment 6 2010-09-24 01:16:59 PDT
(In reply to comment #5) > Actually, per http://dev.w3.org/csswg/cssom/ you should not throw a SYNTAX_ERR (just ignore it). I'm not sure how you can get a CSSStyleRule separately from a style sheet. You are correct. It's just I didn't connect this fact with the usage of CSSStyleRule::setSelectorText in JSCSSStyleRule.cpp. Anyway, if I implement it to always return "no error", it will be hard to tell if the operation has succeeded (e.g. due to a wrong selector list syntax).
Alexander Pavlov (apavlov)
Comment 7 2010-09-24 01:56:46 PDT
Created attachment 68661 [details] [PATCH] Do not return an ExceptionCode in the event of an error in setSelectorText()
Alexander Pavlov (apavlov)
Comment 8 2010-09-24 02:10:14 PDT
Error handling fixed, I've got another question: is doc->styleSelectorChanged(RecalcStyleImmediately); the right way to notify the document of the rule selector change?
Anne van Kesteren
Comment 9 2010-09-24 03:01:51 PDT
You can tell if setting succeeded by comparing the new string with the old string. A lot of web platform APIs taking strings work this way.
Alexander Pavlov (apavlov)
Comment 10 2010-09-24 03:26:36 PDT
(In reply to comment #9) > You can tell if setting succeeded by comparing the new string with the old string. A lot of web platform APIs taking strings work this way. That's right - I didn't mean to say it was impossible (I said "hard" :)). But since I'm working directly with the CSSStyleRule native instance, I'd like to have a simple means of detecting the operation success/failure. I believe the API was dictated by the IDL and not intended to be interacted with from the native code. On a related note, you must know that the selectorText setter previously used to raise DOMException, as per http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleRule, not unreasonably, I should say :)
Alexander Pavlov (apavlov)
Comment 11 2010-09-24 03:31:59 PDT
(In reply to comment #9) > You can tell if setting succeeded by comparing the new string with the old string. A lot of web platform APIs taking strings work this way. Ah, one more note. This approach will likely fail when setting the same selector (an idempotent operation), since the serialized selector list is canonicalized in the sense that extraneous whitespace is removed. Thus, "div span" (one space) and "div span" (two spaces) correspond to the same selector, but cssRule.selectorText will return "div span" in both cases making one think that the operation has failed.
Sam Weinig
Comment 12 2010-09-24 10:52:24 PDT
Comment on attachment 68661 [details] [PATCH] Do not return an ExceptionCode in the event of an error in setSelectorText() This should be broken into two at least two patches, one for the implementation of setSelectorText with tests, and one for the rest of the patch.
Alexander Pavlov (apavlov)
Comment 13 2010-09-27 09:19:04 PDT
Created attachment 68918 [details] [PATCH] Only source offsets extraction for rule selectors
Alexander Pavlov (apavlov)
Comment 14 2010-09-28 01:29:27 PDT
Created attachment 69031 [details] [PATCH] Fix selector list end detection
Alexander Pavlov (apavlov)
Comment 15 2010-10-05 09:07:43 PDT
Created attachment 69794 [details] [PATCH] Rebase + small API change
Early Warning System Bot
Comment 16 2010-10-05 09:17:13 PDT
Eric Seidel (no email)
Comment 17 2010-10-05 09:27:04 PDT
Alexander Pavlov (apavlov)
Comment 18 2010-10-05 10:14:25 PDT
Created attachment 69804 [details] [PATCH] Rebase for compilability
Timothy Hatcher
Comment 19 2010-10-05 10:17:27 PDT
What is the UI for this?
Pavel Feldman
Comment 20 2010-10-05 10:37:21 PDT
(In reply to comment #19) > What is the UI for this? There are no changes to the UI. The ultimate goal is to add support for style properties not supported by WebKit (moz- and such) without changing the style editing UI. We will also get persistence for local modifications and such. We are fairly close to switching to it!
Pavel Feldman
Comment 21 2010-10-06 05:42:16 PDT
Comment on attachment 69804 [details] [PATCH] Rebase for compilability View in context: https://bugs.webkit.org/attachment.cgi?id=69804&action=review Overall looks good. Few nits from me and we are ready to land. > WebCore/css/CSSParser.cpp:-152 > - , m_currentStyleData(0) Do not remove this line. You could access style data via rule data.
Alexander Pavlov (apavlov)
Comment 22 2010-10-06 07:31:49 PDT
Created attachment 69938 [details] [PATCH] Comment addressed
Alexander Pavlov (apavlov)
Comment 23 2010-10-06 08:46:00 PDT
Note You need to log in before you can comment on or make changes to this bug.