- From: Chris Lilley via GitHub <sysbot+gh@w3.org>
- Date: Wed, 26 Sep 2018 23:22:10 +0000
- To: public-css-archive@w3.org
svgeesus has just created a new issue for https://github.com/w3c/csswg-drafts: == [css-variables][css-conditional] passing lone surrogates to CSS.supports() == from https://lists.w3.org/Archives/Public/www-style/2013Aug/0546.html by @heycam > The definition of the two argument version of CSS.supports() says: > When the supports() method is invoked with two arguments property and value, it must return true if property is a literal match for the name of a CSS property that the UA supports, and value would be successfully parsed as a supported value for that property. (Literal match means that no CSS escape processing is performed, and leading and trailing whitespace are not stripped, so any leading whitespace, trailing whitespace, or CSS escapes equivalent to the name of a property would cause the method to return false.) > What is the set of custom property names that the UA supports? Is it all property names that begin with "var-" and are at least 5 characters long? And are these Unicode characters, or UTF-16 code units? > I am wondering about: > CSS.supports("var-\ud800", "a") > If we are thinking of property names as being sequences of UTF-16 code units, then there is no way of writing that property name, since `var-\d800` will be interpreted the same as `var-\fffd`. And if that's the case, should "var-\ud800" be considered to be the name of a supported (custom) property? > If we are thinking of property names as being sequences of Unicode characters, then we need to specify how the first argument string is interpreted. If we used http://dev.w3.org/2006/webapi/WebIDL/#dfn-obtain-unicode then that string would get converted to the sequence of characters <'v', 'a', 'r', '-', U+FFFD>, and then we do have the name of a supported (custom) property. > A related case is: > CSS.supports("var-\0", "a") > Again, in CSS syntax `var-\0` would be treated the same as `var-\fffd`, but if we're doing a literal match of the property name, then there is no way we could ever have a custom property named with a NUL in its name. Please view or discuss this issue at https://github.com/w3c/csswg-drafts/issues/3168 using your GitHub account
Received on Wednesday, 26 September 2018 23:22:11 UTC