-
Notifications
You must be signed in to change notification settings - Fork 41
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
HTML Ruby PR Escalation to WHATWG SG #184
Comments
The Steering Group has reviewed this escalation and members of the SG are amenable to the prospect of having a Ruby Extension specification published by the W3C according to option 2 noted above. The SG is interested in further validating this decision with its HTML community and has filed whatwg/html#7405 to solicit any feedback and concerns. Pending substantial negative feedback (and we should give about a month for folks to respond given we are entering into the end-of-year holiday season), we believe an updated Ruby Extension spec, kept in sync as much as possible with the current Ruby prose in the HTML specification, is the best way forward. We appreciate your interest in preparing a document that we all agree can eventually be integrated back into HTML when browser implementations of the extension are ready or near-term committed.
By mid-January 2022, barring any substantial negative feedback from the HTML community, this plan shall be committed and documented in the W3C/WHATWG Coordination repository. |
This was resolved by w3c/whatwg-coord#14. |
Hello WHATWG SG,
This message concerns “ruby”, which is a form of interlinear annotations commonly used in East Asia, primarily (but not exclusively) for phonetic assistance. It is an important typographic feature as well as a critical accessibility feature for languages such as Japanese, where it is notably relied on by virtually all language learners, including by all school-age children.
I'm writing specifically to escalate the matter of the rejected PR to synchronize the W3C and WHATWG HTML ruby specifications.
Aside from substantially rewriting the prose and examples, the pull request does three things:
This PR resolves what is, afaik, the only major intentional difference between the WHATWG and W3C HTML specs (prior to the MOU), incorporating the broadly consensus-backed W3C extended ruby markup model into the WHATWG spec.
We have two implementations of the first (RB) feature: Mozilla Firefox and Amazon Kindle. (But I am told that Kindle does not count as far as WHATWG is concerned, since it is not a "Web browser".) The second (RTC) feature is currently only implemented by Mozilla afaik (and is somewhat less critical).
The background on this PR starts more than 10 years ago; to understand it probably the best place to start is this blog post:
https://fantasai.inkedblade.net/weblog/2011/ruby/
For more examples and explanations there's also the content of the HTML PR, which is posted here:
https://html.rivoal.net/multipage/text-level-semantics.html#the-ruby-element
These two should explain the use cases and requirements, and the resulting technical design, of the extended markup model.
From a historical perspective, fantasai's post kicked off two efforts in coordination with the i18nwg:
https://www.w3.org/TR/html-ruby-extensions/ in the HTMLWG
This eventually got incorporated into W3C HTML5, but, due to Hixie's objections to adding anything more complicated than what he personally thought was adequate, never made it into WHATWG HTML.
https://www.w3.org/TR/css-ruby-1/ in the CSSWG
The modern CSS Ruby Layout spec, which handles all the markup patterns described in the blog post.
Thanks to Koji Ishii, Robin Berjon, Henri Sivonen, and the i18nwg's efforts, all browser engines implemented the relevant parsing rules for the full set of ruby elements awhile back, and this has been incorporated into the HTML parsing algorithm across all specs and implementations.
Subsequently the Ruby Markup Extension spec was retired as a W3C NOTE and its contents incorporated into the W3C HTML REC.
Xidorn Quan (@upsuper) then implemented the new CSS Ruby layout model in Gecko, and used it to implement layout support for the full HTML ruby extensions spec in Firefox. He later filed an issue to have WHATWG sync with W3C's HTML spec, which then stalled.
At the 2018 TPAC the W3C i18nwg and WHATWG editors discussed the situation of HTML ruby markup, as it was a major technical issue that the W3C community found unsatisfying in the WHATWG specification. The i18nwg promised to provide a PR, and the WHATWG would merge the PR provided Firefox's CSS implementation and a second layout implementation commitment.
This PR was provided in March 2020, at which point the WHATWG editors clarified that the second implementation must be "a second implementation approved for shipping" of support for layout of the extended markup, and cannot be anything but WebKit or Blink because WHATWG policy only considers web browsers to be implementations. See whatwg/html#1771 (comment)
Thus currently we find ourselves in an awkward position:
There are, afaict, two ways out of this situation:
WHATWG merges the PR without a second browser implementation
W3C publishes a Ruby Extension Recommendation
Note: In this second case, we would provide a PR to update the WHATWG specification to remove the features that were never implemented and to ensure that, in both technical and editorial respects, the specifications are synchronized and appropriately cross-referenced to each other such that the WHATWG specification clearly defines a semantically compatible subset of the W3C extended ruby model.
The question I am putting before the WHATWG Steering Group is, which of these two approaches would it prefer to take?
~fantasai
The text was updated successfully, but these errors were encountered: