WebKit Bugzilla
New
Browse
Search+
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
86146
Implement css3-conditional's @supports rule
https://bugs.webkit.org/show_bug.cgi?id=86146
Summary
Implement css3-conditional's @supports rule
Pablo Flouret
Reported
2012-05-10 14:20:11 PDT
The ‘@supports’ rule is a conditional group rule whose condition tests whether the user agent supports CSS property:value pairs.
http://dev.w3.org/csswg/css3-conditional/#at-supports
Attachments
Patch
(16.30 KB, patch)
2012-05-10 14:38 PDT
,
Pablo Flouret
no flags
Details
Formatted Diff
Diff
Patch
(58.61 KB, patch)
2012-08-24 19:51 PDT
,
Pablo Flouret
koivisto
: review+
webkit.review.bot
: commit-queue-
Details
Formatted Diff
Diff
Archive of layout-test-results from gce-cr-linux-04
(677.62 KB, application/zip)
2012-08-24 21:07 PDT
,
WebKit Review Bot
no flags
Details
Patch for landing
(65.64 KB, patch)
2012-10-17 12:27 PDT
,
Pablo Flouret
no flags
Details
Formatted Diff
Diff
Show Obsolete
(1)
View All
Add attachment
proposed patch, testcase, etc.
Pablo Flouret
Comment 1
2012-05-10 14:38:07 PDT
Created
attachment 141261
[details]
Patch CSS is not really in my area of expertise, so excuse any newbie mistakes :-). I suspect this needs more tests, suggestions very welcome.
Andreas Kling
Comment 2
2012-05-16 11:35:10 PDT
Implementation aside, I worry about claiming in such explicit terms that we "support" a given property simply because we can parse it.
Paul Irish
Comment 3
2012-05-17 17:49:20 PDT
Sir awesomekling, For Webkit to successfully parse a css property/value pair but not "support" it is a false positive for feature detection and should be avoided. For the most part, vendors to avoid successfully parsing and unsuccessfully implementing, (and Modernizr /HTML5Test/Caniuse/etc all file tickets when they don't) so I feel this dependency is fair.
Andreas Kling
Comment 4
2012-05-17 18:12:02 PDT
@Paul: Fair enough, then I have no objections here. :)
Pablo Flouret
Comment 5
2012-05-31 14:43:08 PDT
Ping? (can anyone suggest relevant reviewers if they're not cc:ed?)
Pablo Flouret
Comment 6
2012-08-02 09:51:53 PDT
Mozilla has this now:
https://bugzilla.mozilla.org/show_bug.cgi?id=649740
Pablo Flouret
Comment 7
2012-08-02 12:58:27 PDT
Unofficial reports that it's coming to Opera as well:
https://twitter.com/frivoal/status/231101124298547200
Peter Beverloo
Comment 8
2012-08-02 13:00:57 PDT
(In reply to
comment #7
)
> Unofficial reports that it's coming to Opera as well:
https://twitter.com/frivoal/status/231101124298547200
Florian works for Opera, so you can see that as a confirmation.
Peter Beverloo (cr-android ews)
Comment 9
2012-08-14 05:44:30 PDT
Comment on
attachment 141261
[details]
Patch
Attachment 141261
[details]
did not pass cr-android-ews (chromium-android): Output:
http://queues.webkit.org/results/13485882
Peter Beverloo
Comment 10
2012-08-22 06:52:11 PDT
Comment on
attachment 141261
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=141261&action=review
Informal review. You can ignore the cr-android-ews failure. Should we split up the tests into multiple files? That way, filenames can be used to identify what exactly is being tested, considering in a big list like this (without per-test comments) it may not always be obvious for someone unfamiliar with CSS Conditional Rules. Feel free to hold off on that unless a reviewer feels the same though, as it'd be a lot of work. Ports which don't want this feature (yet) can't disable it right now. Should we add a compile-time feature define, i.e. ENABLE_CSS_CONDITIONAL_RULES?
> Source/WebCore/css/CSSGrammar.y:473 > + | supports
The specification currently is a young Working Draft, so I think we should prefix this. Mozilla decided not to prefix (
https://bugzilla.mozilla.org/show_bug.cgi?id=649740
), but it's not entirely obvious to me why.
> LayoutTests/css3/supports.html:27 > + @supports not not not not (display: none) {
This is incorrect, the declaration following a "not" negation must always be surrounded by parenthesis.
> LayoutTests/css3/supports.html:30 > +
Maybe add a test for double negation? i.e. @supports not (not (display: block)) {}
> LayoutTests/css3/supports.html:122 > + @supports(((((((display: none))))))) {
The latest Editor's Draft mentions this syntax for supports_rule: "SUPPORTS_SYM S+ supports_condition group_rule_body" Which implies that one or more space characters need to follow the @supports rule. Mozilla's implementation does not mandate this requirement. Is there some part of the specification I'm missing?
> LayoutTests/css3/supports.html:129 > +
Some idea for more tests: - Do functions work as property values? - What about functions that'll be evaluated later, i.e. using calc()? Variables are valid values too, but their value is derived from parent rules. I guess that means that it's impossible to test support for properties which values use variables, despite them being valid.
Pablo Flouret
Comment 11
2012-08-22 18:05:07 PDT
(In reply to
comment #10
)
> (From update of
attachment 141261
[details]
) > View in context:
https://bugs.webkit.org/attachment.cgi?id=141261&action=review
> > Ports which don't want this feature (yet) can't disable it right now. Should we add a compile-time feature define, i.e. ENABLE_CSS_CONDITIONAL_RULES?
Can do.
> > Source/WebCore/css/CSSGrammar.y:473 > > + | supports > > The specification currently is a young Working Draft, so I think we should prefix this. Mozilla decided not to prefix (
https://bugzilla.mozilla.org/show_bug.cgi?id=649740
), but it's not entirely obvious to me why.
I didn't prefix it because i thought it would defeat the whole purpose, and it also seemed like a simple feature with syntax that was agreed upon by enough people, but i guess you never know with the csswg :P Mozilla has this to say (that i could find): "[*] As prefixing this at-rule has no sense, the @supports at-rule is only supported if the user enables it by setting the config value layout.css.supports-rule.enable to true." From
https://developer.mozilla.org/en-US/docs/CSS/@supports
I'll ask the opera guys what they're planning.
> > LayoutTests/css3/supports.html:27 > > + @supports not not not not (display: none) { > > This is incorrect, the declaration following a "not" negation must always be surrounded by parenthesis.
Right, i misread the grammar.
> > LayoutTests/css3/supports.html:122 > > + @supports(((((((display: none))))))) { > > The latest Editor's Draft mentions this syntax for supports_rule: > "SUPPORTS_SYM S+ supports_condition group_rule_body" > > Which implies that one or more space characters need to follow the @supports rule. Mozilla's implementation does not mandate this requirement. Is there some part of the specification I'm missing?
Everywhere else S* is used, so i think it was just inertia on my part. Maybe the same thing happened to Cameron?. Funnily enough, it doesn't seem like they pass the tests in this patch that don't have whitespace between the operators and the conditions (i.e. #t21 to #t24).
Tab Atkins
Comment 12
2012-08-22 18:58:14 PDT
(In reply to
comment #11
)
> (In reply to
comment #10
) > > > Source/WebCore/css/CSSGrammar.y:473 > > > + | supports > > > > The specification currently is a young Working Draft, so I think we should prefix this. Mozilla decided not to prefix (
https://bugzilla.mozilla.org/show_bug.cgi?id=649740
), but it's not entirely obvious to me why. > > I didn't prefix it because i thought it would defeat the whole purpose, and it also seemed like a simple feature with syntax that was agreed upon by enough people, but i guess you never know with the csswg :P > > Mozilla has this to say (that i could find): > "[*] As prefixing this at-rule has no sense, the @supports at-rule is only supported if the user enables it by setting the config value layout.css.supports-rule.enable to true." > From
https://developer.mozilla.org/en-US/docs/CSS/@supports
> > I'll ask the opera guys what they're planning.
Please do not prefix it. We can keep it off the stable channel until it's ready, but prefixing would, as you say, completely defeat the purpose. We discussed this a few weeks ago at the CSSWG face-to-face.
Peter Beverloo
Comment 13
2012-08-23 04:04:12 PDT
(In reply to
comment #12
)
> Please do not prefix it. We can keep it off the stable channel until it's ready, but prefixing would, as you say, completely defeat the purpose. We discussed this a few weeks ago at the CSSWG face-to-face.
Ok, agreed. In that case we definitely need a compile-time flag.
Pablo Flouret
Comment 14
2012-08-24 19:51:38 PDT
Created
attachment 160546
[details]
Patch
Pablo Flouret
Comment 15
2012-08-24 19:53:46 PDT
(In reply to
comment #14
)
> Created an attachment (id=160546) [details] > Patch
Added the ENABLE flag and a few more tests.
WebKit Review Bot
Comment 16
2012-08-24 21:07:50 PDT
Comment on
attachment 160546
[details]
Patch
Attachment 160546
[details]
did not pass chromium-ews (chromium-xvfb): Output:
http://queues.webkit.org/results/13599350
New failing tests: css3/supports.html
WebKit Review Bot
Comment 17
2012-08-24 21:07:56 PDT
Created
attachment 160552
[details]
Archive of layout-test-results from gce-cr-linux-04 The attached test failures were seen while running run-webkit-tests on the chromium-ews. Bot: gce-cr-linux-04 Port: <class 'webkitpy.common.config.ports.ChromiumXVFBPort'> Platform: Linux-2.6.39-gcg-201203291735-x86_64-with-Ubuntu-10.04-lucid
Antti Koivisto
Comment 18
2012-10-04 11:13:28 PDT
Comment on
attachment 160546
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=160546&action=review
> Source/WebCore/css/CSSGrammar.y:663 > ; > > +supports: > + SUPPORTS_SYM maybe_space supports_condition '{' maybe_space block_rule_list save_block {
I think it would be good to add feature #if to the grammar too so keep track of everything that belongs to this feature.
Bug 94290
has a WIP patch...
Tab Atkins
Comment 19
2012-10-09 14:19:19 PDT
(In reply to
comment #10
)
> > LayoutTests/css3/supports.html:122 > > + @supports(((((((display: none))))))) { > > The latest Editor's Draft mentions this syntax for supports_rule: > "SUPPORTS_SYM S+ supports_condition group_rule_body" > > Which implies that one or more space characters need to follow the @supports rule. Mozilla's implementation does not mandate this requirement. Is there some part of the specification I'm missing?
Since @media has an S* there (and everyone is interop about it), we've changed @supports to match.
Pablo Flouret
Comment 20
2012-10-17 12:27:21 PDT
Created
attachment 169233
[details]
Patch for landing No substantial changes. Rebased, added feature ifdefs in grammar file, skipped the tests in TestExpectation files.
WebKit Review Bot
Comment 21
2012-10-18 11:43:22 PDT
Comment on
attachment 169233
[details]
Patch for landing Clearing flags on attachment: 169233 Committed
r131783
: <
http://trac.webkit.org/changeset/131783
>
Kent Tamura
Comment 22
2012-10-18 19:13:19 PDT
Would you add CSS_CONDITIONAL_RULES to
http://trac.webkit.org/wiki/FeatureFlags
please?
Pablo Flouret
Comment 23
2012-10-19 10:42:05 PDT
(In reply to
comment #22
)
> Would you add CSS_CONDITIONAL_RULES to
http://trac.webkit.org/wiki/FeatureFlags
please?
Yeah, i'll get to it once i manage to log into trac.
Paul Irish
Comment 24
2012-10-20 15:23:07 PDT
Is there a complementary ticket for supportsCSS()? (Mozilla and Opera completed their implementation with it as well)
Pablo Flouret
Comment 25
2012-10-20 18:49:09 PDT
(In reply to
comment #24
)
> Is there a complementary ticket for supportsCSS()? > (Mozilla and Opera completed their implementation with it as well)
I don't think so, but i was planning on looking at that next week. Feel free to file a bug for it and cc me.
Tab Atkins
Comment 26
2012-10-20 18:51:29 PDT
(In reply to
comment #25
)
> (In reply to
comment #24
) > > Is there a complementary ticket for supportsCSS()? > > (Mozilla and Opera completed their implementation with it as well) > > I don't think so, but i was planning on looking at that next week. Feel free to file a bug for it and cc me.
Special very important note! The function was renamed to just "supports()", on a new global CSS object. Check the Editor's Draft for details.
Radar WebKit Bug Importer
Comment 27
2014-09-03 14:01:11 PDT
<
rdar://problem/18219801
>
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