-
Notifications
You must be signed in to change notification settings - Fork 685
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[css-fonts-4][css-nesting] Nesting of @supports inside @font-face and font technology feature queries #6520
Comments
This seems obvious but checking just in case: your proposal @LeaVerou is to allow |
Currently it is for |
CC @jfkthame I'll investigate what that would entail from an implementation point of view (complexity, overhead) and comment once I have some findings. One consideration from a readability point of view: If we introduce such a
FWIW, the "parsing weirdness" may be considered addressed or improved with the most recent change which references the CSS syntax spec for parsing a comma separated list of components. |
How is the supports rule represented in the OM? Implementation-wise I think it'd be easier for us if it just disappeared, but... |
Hi @drott!
Yeah, this was raised by @plinss as well. The counter-argument he agreed to was that
I was referring to the fact that this descriptor's syntax needs prose and cannot be fully described by a grammar. I wasn't even aware that it used to be even weirder, whoa!
I've wondered about this too, but I'm afraid making it disappear would be fairly inconsistent with every other @-rule, which would be even more confusing once Nesting is implemented. |
While it would involve more duplication, would it be okay to just leverage @supports normally, with some new queries to ask about various font-feature support, and then just have @font-face as a child of the rule like normal? The big argument against is if we think multiple independent queries affecting different bits would be common; you'd have a combinatorial explosion to achieve equivalent results. |
Looking at the proposal itself - it feels slightly weird to have context-specific @supports (I presume this wouldn't allow arbitrary property-support queries, but only font-based ones?). If I'm wrong about that and this would just be an ordinary @supports, with a supporting proposal to add the font-feature queries, then this is less weird. (If I'm right, naming it I don't have a strong opinion on whether this should be treated as a parse-time syntax, disappearing from the tree in the OM, or kept around like normal @supports is. Parse-time is definitely simpler overall, but I understand how it feels new and odd. Overall tho, I definitely support something like this over the growing weird microsyntax. The microsyntax was reasonable when it was just one thing, but it's getting out of hand. |
I think that could be a good first step, and would enable authors to do what they want with some duplication, and would likely (?) be relatively easy to implement. However, we do eventually want to avoid the duplication, even if multiple independent queries aren't common.
It is not context-specific. The whole idea is that this way authors can use it to feature detect in any context that suits them, not just to differentiate the |
Having looked at and discussed with my CSS colleagues, the implementation of
Yes, I agree, adding something similar to a This would give us a path that's relatively straight-forward to implement and not blocked on nesting |
I think adding the Adding this to the agenda so we can resolve that these changes have CSS WG consensus. |
In this branch I drafted an edit to css-conditional-4, carrying over the syntax from fonts-4's - Parsing the source descriptor, an excerpt from that draft (feel free to comment on the commit directly as well):
Considerations:
I'd be very happy if in tomorrow's meeting we could attempt to resolve towards a direction of the syntax along those lines (feedback very welcome), in addition to the general aim to resolve adding the criteria to the |
I agree, more readable that way. |
Just to be sure I understand, the first example in the /* 1. prefer COLRv1, then SVG-in-OpenType, then COLRv0 */
@font-face {
font-family: jewel;
src: url(boring.ttf) format("woff2");
}
@supports font-technology(color(COLRv0)) {
@font-face {
font-family: jewel;
src: url(jewel-v0.woff2) format("woff2");
}
}
@supports font-technology(color(SVG)) {
@font-face {
font-family: jewel;
src: url(jewel-svg.woff2) format("woff2");
}
}
@supports font-technology(color(COLRv1)) {
@font-face {
font-family: jewel;
src: url(jewel-v1.woff2) format("woff2"),;
}
} |
Yes, that's how I would express it as well. That is: for now, without nested |
@dbaron @fantasai thoughts? Since we are all editors of Conditional 3 I assume we are of Conditional 4 too, right? |
Oh wait
So that is like @supports (font-technology(color(COLRv0))) {
and so on |
This applies to declaration tests, not Nitpick, I don’t think we need nested function calls, not to mention |
Incorporates @LeaVerou's feedback from w3c#6520 (comment)
Updated the proposed change with that suggestion, thanks. |
@svgeesus asked yesterday if we could use colons ( |
So, that would be /* 1. prefer COLRv1, then SVG-in-OpenType, then COLRv0 */
@font-face {
font-family: jewel;
src: url(boring.ttf) format("woff2");
}
@supports font-technology(color-COLRv0) {
@font-face {
font-family: jewel;
src: url(jewel-v0.woff2) format("woff2");
}
}
@supports font-technology(color-SVG) {
@font-face {
font-family: jewel;
src: url(jewel-svg.woff2) format("woff2");
}
}
@supports font-technology(color-COLRv1) {
@font-face {
font-family: jewel;
src: url(jewel-v1.woff2) format("woff2"),;
}
} |
Its also weird to have key-value pairs multiple times for the same key @supports font-technology(color: COLRv0) AND font-technology(color: COLRv1) so on balance I prefer the hyphenated form proposed earlier. |
Resolved in today's meeting to discuss in breakout right before the regular meeting time next week. @drott could you please coordinate the logistics of said breakout? |
Yes, I'll send details and and invite to a Meet call to the private mailing list. |
@svgeesus From your example, format("color-COLRv1") and format("woff color-COLRv1") would both fail to load because neither string is a recognized font format. |
Within the comma separated list, things are supposed to be space separated. Which is why format(opentype supports incremental) works in a backward compat way. As you say, older browsers treat the whole thing as one unknown format that happens to contain spaces. |
@fantasai's proposal in #6520 (comment) makes sense to me. Regarding the question of whether or not we can avoid changing the A quick check shows that, in today's browsers (which are the first situation above),
does not cause On the other hand,
does cause If we can come up with a solution that satisfies these constraints, we can leave the Of course, another way to solve this problem is to wait to implement (but not necessarily spec) this fancy new
If these two features ( |
@litherum My understanding of the |
I tend to agree with @LeaVerou here, with
(https://drafts.csswg.org/css-conditional-3/#at-supports) only the second part of your example is valid syntax.
I am assuming the intent in your examples is to get blue background, or in other words: "use this block for fallback" is the intention. It seems to me we we can conclude this syntax (with condition in parentheses) would fulfil your expectation of code a) working in old browsers without |
The CSS Working Group just discussed
The full IRC log of that discussion<dbaron> topic: fonts, continued (beginning of log missing)<dbaron> github: https://github.com//issues/6520 <lea> q? <fantasai> astearns: jfkthame is suggesting to re-use format() not add new function <fantasai> jfkthame: ... <fantasai> chris: Because existing format function requires a font format <fantasai> jfkthame: I don't see why not <fantasai> jfkthame: would work just the same as not specifying format function at all <fantasai> jfkthame: except now filtered by the tech keywords you just expressed <lea> q+ <fantasai> drott: Currently state of format() is quite messy and not quite inteorp <florian> q- later <fantasai> drott: Some accept strings, some keywords, some both <fantasai> drott: New function we have the potential of cleaning that up a bit <drott> q- <astearns> ack fantasai <Zakim> fantasai, you wanted to ask about fallback in legacy browsers and to <drott> q+ <fantasai> fantasai: One point about format() is it wouldn't invalidate src declaration in older browsers <fantasai> fantasai: whereas a new function would <fantasai> fantasai: As for jfkthame's proposal, I think it would work <fantasai> fantasai: it would mean that the font-tech keywords would be in the same namespace as any format keywords, so you'd have to be careful to avoid name clashes <fantasai> fantasai: but otherwise seems easily parsable <drott> q- <fantasai> astearns: One argument against format() is that then we can't use the same syntax in @supports, as context is lost has to be font-format() <astearns> ack PeterCon <fantasai> PeterCon: Might be edge case, but different tech ... <fantasai> PeterCon: Variations technology is binary, font is either variable or not <fantasai> PeterCon: feature capabilities are mutually exclusive <TabAtkins> I think `@supports font-format()` works fine - the connection to @font-face's format() seems clear that you're qualifying it now that it's in a more generic context. <fantasai> PeterCon: Font could have either AAT or Graphite, but impl only wants to use one or the other <fantasai> PeterCon: If the font has both, perhaps author prefers one or other <fantasai> PeterCon: So may want to specify which <fantasai> PeterCon: In a fallback case, they might tolerate the second choice and not the first <fantasai> PeterCon: Color tech is potentially complementary <fantasai> PeterCon: Font might have both and use it for different glyphs <fantasai> PeterCon: iN that case, might be happy to have both <fantasai> PeterCon: An author potentially might say, I want to use this font but only use the ?? color list, not any of color-v0 <myles> q+ <fantasai> PeterCon: Idk if these are too edge case to worry about <fantasai> drott: I don't think necessarily that we want to describe which part of font to use <fantasai> drott: this is just syntax for ??? <fantasai> drott: I don't think we have tools for choosing the tech, that would be a separate thing <fantasai> myles: ... <drott> s/ ???/selection \/ download choice/ <fantasai> myles: It's not a subsetting feature <chris> s/?? color/sbix color/ <astearns> ack lea <fantasai> lea: It occurred to me that format wasn't originally for feature description, but to meta describe the URL <fantasai> lea: This is a woff font, this is opentype <fantasai> lea: [something about calling something woff but getting an opentype and whether it opens it or rejects] <fantasai> myles: I think it's specced <chris> format was added because we did not (at the time) have font MIME types <fantasai> myles: If browser has already downloaded font, why should not use it? <fantasai> lea: I thought it was defined to describe the resource <chris> q? <astearns> ack florian <fantasai> lea: but maybe it was defined as feature detection? <fantasai> fantasai: kinda was <fantasai> florian: fantasai noted that putting both tech keyword would share namespace <fantasai> florian: could have some syntax to divide, e.g. "with color-v1" <fantasai> florian: Issue <fantasai> florian: We say space-separated list is "and" not "or" <fantasai> florian: fine, but might be two different meanings for "and" <myles> [ ( woff | opentype | svg)? WITH [variations, color-sbix, opentype-features]# ] <fantasai> florian: Do you support this and that? <fantasai> florian: do you support both in the same file? <fantasai> florian: slightly different question <fantasai> florian: just to make sure this is forward proof might need to think about it <astearns> q? <astearns> ack myles <fantasai> myles: Right now there's nothing in CSS that lets you say "use this part of the font, but not the other" <fantasai> myles: I think that's good, because I don't think it's implementable <fantasai> myles: I don't think we should add a feature that let's you ignore certain tables <fantasai> fantasai: If we were to do so, I think it wouldn't be in src, should be its own descriptor <drott> fantasai: if we would do that, it should be outside src descriptor <fantasai> astearns: It sounds to me that we do have consensus to modify src descriptor to add font-tech detection somehow <florian> Myles' sample syntax higher up is what I mean, except for the comas (and with an allowance for bikesheding the keyword WITH) <fantasai> myles: Tab said something in IRC that made a lot of sense <fantasai> myles: Could do jfkthame's idea for extending format() <fantasai> myles: and have the same value syntax but different function name in @supports <fantasai> fantasai: Yes, that was my proposal in the issue (using format() and font-format()) <florian> q? <florian> q+ <fantasai> chris: Or we could use font-technology(), I'd prefer that <fantasai> chris: but won't stand in the way <lea> +1 to chris's point <fantasai> chris: I think it's poor design to ??? <drott> s/???/throw it all in the format descriptor/ <fantasai> myles: I think if we're adding tech queries to @supports, should also allow format queries. So if we want distinct functions, then should have both in @supports <drott> s/descriptor/function/ <fantasai> florian: Did anyone address fantasai's point about dropping the src descriptor if adding new function <fantasai> florian: My understanding is if we extend format() will be OK, if add new function will throw out entire src declaration <fantasai> myles: I'm not sure that distinction is true, thinking to how we parse src ... <fantasai> myles: if you put format(keyword keyword) maybe it gets dropped entirely <fantasai> florian: could put it all inside one string? <fantasai> [no that's terrible] <fantasai> myles: You do that by having two declarations <fantasai> chris: Dropping one item in list is OK, dropping entire declaration is a bit of a problem <fantasai> florian: If space-separated keywords in format(), do we drop the entire declaration or treat as unknown format? <astearns> ack florian <fantasai> chris: Unknown format <fantasai> florian: probably should check implementations <fantasai> lea: In my test seems like entire descriptor is dropped <fantasai> florian: that's sad <fantasai> lea: So I think we should use a new function <fantasai> astearns: I think we can resolve that we add font-tech detection to src descriptor <fantasai> astearns: is that the case? anyone arguing against and only wants @supports? <lea> FYI to test I was using this: https://codepen.io/leaverou/pen/c02cfbe57388cca2399ee427c58e9f19 and checking what requests are sent to my localhost <fantasai> RESOLVED: Modify src to allow for font-tech detection per URL <fantasai> astearns: Next, can we decide on whether we're extending format() or adding new function? <fantasai> lea: I just tested chrome <fantasai> [fussing with the test] <fantasai> florian: Another thing we can resolved, whichever form we add to add to src descriptor, we will expose that to @supports, possibly with font- prefix <lea> Just tested Firefox, same <fantasai> astearns: objections to that? <fantasai> RESOLVED: Same syntax available in src, will be available also in @supports, possibly with a font- prefix <drott> slight preference for font-technology <fantasai> florian: ... <lea> slight preference for font-tech as well <fantasai> chris: Spec doesn't say, but fine to add that <fantasai> astearns: I have a slight preference for a separate function, mainly because it makes the microsyntax we're adding slightly more clear <fantasai> astearns: font-tech is not a format, and having two separate names for what you're specifying is very slightly better <fantasai> myles: I'd like to hear from jfkthame <florian> s/.../if we were to go for two functions, would both format and the new function be allowed in @support/ <drott> also solves migrating away from messy state of what format() is <fantasai> jfkthame: I don't have a strong view one way or other, particularly if we don't get a forward-compat benefit from using format() <drott> q+ <fantasai> jfkthame: To my mind these are very similar feature support queries, whether feature of a particular format or feature of a particular technology with the font <astearns> ack drott <fantasai> jfkthame: if people wnat to separate them, it's OK with me <fantasai> drott: Do we remove the current ??? <fantasai> lea: yes <fantasai> chris: Yes, that should all go <fantasai> astearns: So we will add a font-technology() function with some amount of the keywords we've discussed <fantasai> RESOLVED: remove "supports <font-technology>#" <fantasai> florian: if we add format() to @supports, we have to add a font- prefix <fantasai> florian: so shouldn't it be removed from font-technology() within src? <fantasai> chris: Yes, let's be consistent <fantasai> +1 <jfkthame> +1 <fantasai> lea: I thought one of the benefits was to be the same <fantasai> astearns: but consistency is probably preferale <fantasai> astearns: Any objections to technology()? <florian> tech? capability? <fantasai> fantasai: No, but I would prefer a shorter name if we can find one <fantasai> lea: yes, please <fantasai> RESOLVED: add technology() and open bikeshedding issue <lea> given that Chrome needs to ship this soon, if we don't bikeshed soon, it's just de facto font-technology <fantasai> RESOLVED: Add font-technology() and font-format() to @supports <fantasai> with same syntax within the parentheses <fantasai> drott: do we need both? <florian> q+ <fantasai> astearns: prefer to add now, if ppl have objections can remove in the future, but seemed there were some use cases <fantasai> florian: Point about "and" having two meanings, is it a concern? <astearns> ack florian <lea> what if we just add format-* keywords to font-technology()? <fantasai> fantasai: You're "and"-ing over a single font file... <fantasai> myles: The question is what if browser supports two different technologies, but not in the same font <fantasai> florian: I guess you just choke on trying the use the download, which is wasteful but maybe not an issue <fantasai> PeterCon: The example you gave was variable font with SVG table <fantasai> PeterCon: likelihood of creating such a font is not great <fantasai> myles: there's no way to describe variableness in SVG <fantasai> Meeting closed. |
Full minutes posted here: https://www.w3.org/2021/10/20-css-minutes.html |
Since this issue thread is really long and pulls in a lot of related topics, please consider opening new focused issues based on the resolutions above and/or the spec edits that will be made soon. For instance, if we need to bikeshed the |
Edits made to CSS Conditional 4, CSS Fonts 4, and CSS Fonts 5. |
I thought we could get rid of the parsing weirdness around |
We got rid of the weirdness around |
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3197710 Commit-Queue: Dominik Röttsches <drott@chromium.org> Reviewed-by: Anders Hartvoll Ruud <andruud@chromium.org> Cr-Commit-Position: refs/heads/main@{#1046434}
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3197710 Commit-Queue: Dominik Röttsches <drott@chromium.org> Reviewed-by: Anders Hartvoll Ruud <andruud@chromium.org> Cr-Commit-Position: refs/heads/main@{#1046434}
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3197710 Commit-Queue: Dominik Röttsches <drott@chromium.org> Reviewed-by: Anders Hartvoll Ruud <andruud@chromium.org> Cr-Commit-Position: refs/heads/main@{#1046434}
…etection extensions, a=testonly Automatic update from web-platform-tests Support CSS Conditional 5 font feature detection extensions [1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3197710 Commit-Queue: Dominik Röttsches <drott@chromium.org> Reviewed-by: Anders Hartvoll Ruud <andruud@chromium.org> Cr-Commit-Position: refs/heads/main@{#1046434} -- wpt-commits: 44fa87cd7ce5e68233f175065cf070518c6c9955 wpt-pr: 35829
…etection extensions, a=testonly Automatic update from web-platform-tests Support CSS Conditional 5 font feature detection extensions [1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3197710 Commit-Queue: Dominik Röttsches <drott@chromium.org> Reviewed-by: Anders Hartvoll Ruud <andruud@chromium.org> Cr-Commit-Position: refs/heads/main@{#1046434} -- wpt-commits: 44fa87cd7ce5e68233f175065cf070518c6c9955 wpt-pr: 35829
[1] defines two additional conditional functions `font-tech()` and `font-format()` which were introduced after the resolution of TAG review [2] and discussion in the CSS working group [3]. These functions allow conditional CSS to be included depending on level of font support in the font stack of the UA. Feature detection becomes particular important when checking for the level of color font support, as UA capabilities still very and not all user agents provide support for COLRv1 for example. Implement behind `SupportsFontFormatTech` RuntimeEnabledFeatures flag for now, pending I2S. [1] https://www.w3.org/TR/css-conditional-5/#at-supports-ext [2] w3ctag/design-reviews#666 [3] w3c/csswg-drafts#6520 (comment) Bug: 1255685 Change-Id: I96ab292bc9644b049a84e073b367063cdbedd26f Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/3197710 Commit-Queue: Dominik Röttsches <drott@chromium.org> Reviewed-by: Anders Hartvoll Ruud <andruud@chromium.org> Cr-Commit-Position: refs/heads/main@{#1046434} NOKEYCHECK=True GitOrigin-RevId: edc25f50b7faec81cc5538f50364564ff8070ed7
This is related to #633 and this part of css-fonts-4: https://drafts.csswg.org/css-fonts-4/#font-face-src-parsing
A bit late to the party, but I wondered: what if, instead of adding yet another microsyntax for feature detection, we use
@supports
with an appropriatefont-technology()
function (or whatever we want to name it)?We recently resolved to allow nesting of conditional rules inside regular rules, so that authors can do things like:
What if this was allowed in
@font-face
as well? That way, authors could do something like:or
instead of:
Benefits:
src
that this microsyntax has introducedCSS.supports()
API (current syntax also allows programmatic detectability but in a much clunkier wayformat()
is a list of keywords, with no hierarchy. Also, the syntax makes it unclear whether this is a feature query for the browser, or informing the browser what the font file supports.Downsides:
Unlike conditional rules in general, feature queries do not change during the lifetime of the page load, and thus this should not trigger re-interpretation of the
@font-face
rule or be more heavyweight in any other substantial way.If such syntax is used with today's browsers, they drop the
@supports
rule but keep the@font-face
rule, so it does appear forwards compatible. testcaseThere are no implementations of the current syntax, so it may not be too late for the change.
Thoughts, @svgeesus @litherum @fantasai @tabatkins?
The text was updated successfully, but these errors were encountered: