Skip to content
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

Add getHTML() and the serializable concept #10139

Merged
merged 23 commits into from
Apr 4, 2024

Conversation

mfreed7
Copy link
Contributor

@mfreed7 mfreed7 commented Feb 16, 2024

Add getHTML() and the serializable concept for shadow roots. See #8867 (comment) for the rough consensus on how this should work, plus the few comments below that with modifications.

See the corresponding DOM spec PR here: whatwg/dom#1256


/canvas.html ( diff )
/dynamic-markup-insertion.html ( diff )
/index.html ( diff )
/indices.html ( diff )
/infrastructure.html ( diff )
/interaction.html ( diff )
/parsing.html ( diff )
/scripting.html ( diff )
/semantics.html ( diff )

@mfreed7
Copy link
Contributor Author

mfreed7 commented Feb 16, 2024

Parsing MDN data...
Parsing...
Parse Error: (130197,76) unexpected end tag

I'm not sure what this is - I do not get any errors when I build locally, using the build.sh script. Clues appreciated.

source Outdated Show resolved Hide resolved
@domenic
Copy link
Member

domenic commented Feb 16, 2024

I'm not sure what this is - I do not get any errors when I build locally, using the build.sh script. Clues appreciated.

This is due to whatwg/html-build#290. You have some invalid HTML around that line, but the Rust portion of the build step is fixing it up for you. PR preview doesn't run the Rust portion of the build step, so it fails.

You can try applying whatwg/html-build#291 locally. Or you can stare really hard at (130197,76) to find the extra end tag.

@mfreed7
Copy link
Contributor Author

mfreed7 commented Feb 16, 2024

This is due to whatwg/html-build#290. You have some invalid HTML around that line, but the Rust portion of the build step is fixing it up for you. PR preview doesn't run the Rust portion of the build step, so it fails.

Ahh, thanks. Is there a way to run the local build without the Rust, so it matches what the preview does? Generally I try to make sure things build before I put up a PR, so I was disappointed to see this failure.

You can try applying whatwg/html-build#291 locally. Or you can stare really hard at (130197,76) to find the extra end tag.

Thanks. 130197 is a blank line, and I had been staring at 130198 instead. Turns out the problem was on 130196.

@mfreed7
Copy link
Contributor Author

mfreed7 commented Feb 16, 2024

Parse Error: (142841,9) unexpected body end tag

Looks like I'll be uploading a bunch of patches to try to find this one now...

@mfreed7
Copy link
Contributor Author

mfreed7 commented Feb 16, 2024

Parse Error: (142841,9) unexpected body end tag

Looks like I'll be uploading a bunch of patches to try to find this one now...

Side note, as I manually scan for mis-nested tags, it's nice that WHATWG fought for keeping HTML and not switching to XHTML.

source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
Copy link
Contributor Author

@mfreed7 mfreed7 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the review!

source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 15, 2024
See the conversation here:
  whatwg/html#10139

But the TL;DR is that the `<template>` attribute corresponding
to the declarative shadow root `serializable` attribute should
be named in a parallel way to other DSD-related attributes,
meaning it should start with `shadowroot*`.

Bug: 41490936
Change-Id: I40ea496c22147bac7dcdfb74cd7bf4a3abae8be9
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
@annevk
Copy link
Member

annevk commented Mar 18, 2024

Also:

  1. We need a WPT PR that renames away from .tentative and corrects the naming of the shadowrootserializable attribute.
  2. There should be an MDN issue.

@mfreed7
Copy link
Contributor Author

mfreed7 commented Mar 18, 2024

Also:

  1. We need a WPT PR that renames away from .tentative and corrects the naming of the shadowrootserializable attribute.

This is in progress, here and here.

  1. There should be an MDN issue.

Done: mdn/content#32731

chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 18, 2024
The spec is landing:

 whatwg/html#10139

Bug: 41490936
Change-Id: Ia568d9f1adc9623298db6fd470383930fa5d9d9d
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 18, 2024
See the conversation here:
  whatwg/html#10139

But the TL;DR is that the `<template>` attribute corresponding
to the declarative shadow root `serializable` attribute should
be named in a parallel way to other DSD-related attributes,
meaning it should start with `shadowroot*`.

Bug: 41490936
Change-Id: I40ea496c22147bac7dcdfb74cd7bf4a3abae8be9
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 18, 2024
See the conversation here:
  whatwg/html#10139

But the TL;DR is that the `<template>` attribute corresponding
to the declarative shadow root `serializable` attribute should
be named in a parallel way to other DSD-related attributes,
meaning it should start with `shadowroot*`.

Bug: 41490936
Change-Id: I40ea496c22147bac7dcdfb74cd7bf4a3abae8be9
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5375416
Commit-Queue: Di Zhang <dizhangg@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Auto-Submit: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1274374}
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 18, 2024
See the conversation here:
  whatwg/html#10139

But the TL;DR is that the `<template>` attribute corresponding
to the declarative shadow root `serializable` attribute should
be named in a parallel way to other DSD-related attributes,
meaning it should start with `shadowroot*`.

Bug: 41490936
Change-Id: I40ea496c22147bac7dcdfb74cd7bf4a3abae8be9
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5375416
Commit-Queue: Di Zhang <dizhangg@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Auto-Submit: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1274374}
@lukewarlow
Copy link
Member

I can't find a way to unresolve the comment and it's not relevant to this PR anymore since it's been removed, but if Chrome is using HTMLString as a return type it's likely doing nothing more than being a DOMString, or worse case is slower.

For context HTMLString comes from Trusted Types and it's an alias for [StringContext=TrustedHTML] DOMString which does some enforcement of TT when relevant CSP is set.

source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
source Outdated Show resolved Hide resolved
@mfreed7
Copy link
Contributor Author

mfreed7 commented Mar 20, 2024

I can't find a way to unresolve the comment and it's not relevant to this PR anymore since it's been removed, but if Chrome is using HTMLString as a return type it's likely doing nothing more than being a DOMString, or worse case is slower.

For context HTMLString comes from Trusted Types and it's an alias for [StringContext=TrustedHTML] DOMString which does some enforcement of TT when relevant CSP is set.

So this PR has been changed to do HTMLString -> DOMString. But I think perhaps you're talking about the Chromium implementation which does use HTMLString? If so, can you clarify what you think should be changed? Existing serializers like innerHTML and outerHTML are supposed to return HTMLString also, right? I see that in Chromium they don't currently, but I thought I should try to return HTMLString for new things. LMK if that's wrong.

aarongable pushed a commit to chromium/chromium that referenced this pull request Mar 21, 2024
The spec is landing:

 whatwg/html#10139

Bug: 41490936
Change-Id: Ia568d9f1adc9623298db6fd470383930fa5d9d9d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5378423
Auto-Submit: Mason Freed <masonf@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Commit-Queue: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1275958}
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 21, 2024
The spec is landing:

 whatwg/html#10139

Bug: 41490936
Change-Id: Ia568d9f1adc9623298db6fd470383930fa5d9d9d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5378423
Auto-Submit: Mason Freed <masonf@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Commit-Queue: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1275958}
chromium-wpt-export-bot pushed a commit to web-platform-tests/wpt that referenced this pull request Mar 21, 2024
The spec is landing:

 whatwg/html#10139

Bug: 41490936
Change-Id: Ia568d9f1adc9623298db6fd470383930fa5d9d9d
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5378423
Auto-Submit: Mason Freed <masonf@chromium.org>
Reviewed-by: Di Zhang <dizhangg@chromium.org>
Commit-Queue: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1275958}
@annevk
Copy link
Member

annevk commented Mar 21, 2024

I think HTMLString is only relevant for input which is why innerHTML uses it (for its setter).

It seems this PR needs rebasing. I think we should also resolve #10211.

And where you wrote "element or shadow root" you didn't update the variable name. There might be more errors, I didn't read through it all again.

Copy link
Member

@domenic domenic left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The latest changes left things in a bad state, with "DOM parsing and serialization" only containing parsing spec text plus serialization IDL, and the serialization spec text and domintro still far away in a different section.

It was explicitly not my intention to make @mfreed7 resolve this disagreement between the editors in this PR by commenting on #10139 (comment), and I'm sad that my comment there was used to delay landing this. I explicitly said I'd like to work on that as a followup.

To compensate, I took it on myself to do the remaining rearranging to get things into a hopefully-agreeable state, in 1619131.

While there I got nerd-sniped into improving the domintro, which previously didn't follow our existing conventions and didn't explain the options at all. If someone could check that I summarized the behavior correctly, that would be appreciated.

Copy link
Contributor Author

@mfreed7 mfreed7 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for making these edits! Modulo two comments, this LGTM.

source Show resolved Hide resolved
source Show resolved Hide resolved
source Show resolved Hide resolved
Copy link
Contributor Author

@mfreed7 mfreed7 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

source Show resolved Hide resolved
@domenic
Copy link
Member

domenic commented Apr 2, 2024

@annevk want to do a final check? Also I think you should merge whatwg/dom#1256 first?

source Outdated Show resolved Hide resolved
@annevk
Copy link
Member

annevk commented Apr 2, 2024

I'm sad that my comment there was used to delay landing this.

Your opinion on this apparently differs, but I don't think delaying this by a couple days is a big deal, given that it might make blame a lot more useful. I also didn't think @mfreed7 would act on the comment given what you had written there. I wanted to wait with landing until I had some conversation with you about it. I think the changes you made make sense, though Simon just spotted a bigger problem.

annevk pushed a commit to whatwg/dom that referenced this pull request Apr 4, 2024
@annevk annevk merged commit 6c20fe5 into whatwg:main Apr 4, 2024
2 checks passed
@mfreed7
Copy link
Contributor Author

mfreed7 commented Apr 4, 2024

Thanks everyone!

moz-v2v-gh pushed a commit to mozilla/gecko-dev that referenced this pull request Apr 10, 2024
…rialization, a=testonly

Automatic update from web-platform-tests
Add a test of the ordering of getHTML serialization

This adds a test to verify that the serialized version of a shadow
root:
 1. has the `<template shadowroot>` first, before any children,
    regardless of where the initial DSD content put them.
 2. has the various shadowroot* attributes in a well defined order,
    again regardless of where the initial DSD put them.

This came from a comment on the spec PR, here:
 whatwg/html#10139 (comment)

(Note that Github currently doesn't properly handle links to
"Resolved" conversations, and the above conversation is resolved.
So I guess trust me that the request was to add testing for this
case!)

Bug: 41490936
Change-Id: I7866b61b768f645d61142a1fd4a9490ee0732dc2
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5405665
Reviewed-by: David Baron <dbaron@chromium.org>
Commit-Queue: Mason Freed <masonf@chromium.org>
Auto-Submit: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1279973}

--

wpt-commits: 6a072aeb9fcbaa56cab5e168cba7b706268c4d05
wpt-pr: 45415
webkit-commit-queue pushed a commit to annevk/WebKit that referenced this pull request Apr 11, 2024
https://bugs.webkit.org/show_bug.cgi?id=271343
rdar://125513986

Reviewed by Ryosuke Niwa.

This implements whatwg/html#10139 as amended by
whatwg/html#10260.

This also changes the way a shadow root is serialized to avoid creating
a template element.

The API is guarded by DeclarativeShadowRootsSerializerAPIsEnabled just
in case there is a need to disable it without removing the code.

Thanks to Chris Dumez for his help with Vector<RefPtr<ShadowRoot>>.

WPT tests are synchronized up to and including this commit:
web-platform-tests/wpt@dd2e51d

This also adjusts the copyright lines to match the commit log for the
relevant files.

* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/declarative-shadow-dom-repeats-expected.txt:
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/declarative-shadow-dom-repeats.html:
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/gethtml-expected.txt: Added.
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/gethtml-ordering-expected.txt: Added.
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/gethtml-ordering.html: Added.
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/gethtml.html: Added.
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/gethtml.tentative-expected.txt: Removed.
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/gethtml.tentative.html: Removed.
* LayoutTests/imported/w3c/web-platform-tests/shadow-dom/declarative/w3c-import.log:
* LayoutTests/tests-options.json:
* Source/WTF/Scripts/Preferences/UnifiedWebPreferences.yaml:
* Source/WebCore/CMakeLists.txt:
* Source/WebCore/DerivedSources-input.xcfilelist:
* Source/WebCore/DerivedSources-output.xcfilelist:
* Source/WebCore/DerivedSources.make:
* Source/WebCore/Headers.cmake:
* Source/WebCore/Sources.txt:
* Source/WebCore/WebCore.xcodeproj/project.pbxproj:
* Source/WebCore/dom/Element.cpp:
(WebCore::Element::getHTML const):
* Source/WebCore/dom/Element.h:
* Source/WebCore/dom/GetHTMLOptions.h: Added.
* Source/WebCore/dom/GetHTMLOptions.idl: Added.
* Source/WebCore/dom/InnerHTML.idl:
* Source/WebCore/dom/ShadowRoot.cpp:
(WebCore::ShadowRoot::ShadowRoot):
(WebCore::ShadowRoot::getHTML const):
(WebCore::ShadowRoot::cloneNodeInternal):
* Source/WebCore/dom/ShadowRoot.h:
* Source/WebCore/dom/ShadowRoot.idl:
* Source/WebCore/dom/ShadowRootInit.h:
* Source/WebCore/dom/ShadowRootInit.idl:
* Source/WebCore/editing/MarkupAccumulator.cpp:
(WebCore::MarkupAccumulator::MarkupAccumulator):
(WebCore::MarkupAccumulator::shouldIncludeShadowRoots const):
(WebCore::MarkupAccumulator::includeShadowRoot const):
(WebCore::MarkupAccumulator::serializeNodesWithNamespaces):
(WebCore::MarkupAccumulator::replacementElement):
* Source/WebCore/editing/MarkupAccumulator.h:
(WebCore::MarkupAccumulator::MarkupAccumulator):
* Source/WebCore/editing/markup.cpp:
(WebCore::serializeFragment):
* Source/WebCore/editing/markup.h:
(WebCore::serializeFragment):
* Source/WebCore/html/HTMLAttributeNames.in:
* Source/WebCore/html/HTMLTemplateElement.cpp:
(WebCore::HTMLTemplateElement::attachAsDeclarativeShadowRootIfNeeded):
* Source/WebCore/html/HTMLTemplateElement.idl:
* Source/WebCore/html/parser/HTMLConstructionSite.cpp:
(WebCore::HTMLConstructionSite::insertHTMLTemplateElement):
* Source/WebCore/loader/archive/cf/LegacyWebArchive.cpp:
(WebCore::LegacyWebArchive::create):

Canonical link: https://commits.webkit.org/277374@main
aarongable pushed a commit to chromium/chromium that referenced this pull request Apr 11, 2024
I2S:
 - https://groups.google.com/a/chromium.org/g/blink-dev/c/T4jcCXRkwB8/m/GD81-4bNAAAJ

Spec:
 - whatwg/html#10139
 - whatwg/dom#1256

Fixed: 41490936
Change-Id: Ie9b52d5d7a5aa626f1d9f96326c2d4826e11874f
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5427272
Auto-Submit: Mason Freed <masonf@chromium.org>
Reviewed-by: Chris Harrelson <chrishtr@chromium.org>
Commit-Queue: Chris Harrelson <chrishtr@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1285896}
ErichDonGubler pushed a commit to erichdongubler-mozilla/firefox that referenced this pull request Apr 15, 2024
…rialization, a=testonly

Automatic update from web-platform-tests
Add a test of the ordering of getHTML serialization

This adds a test to verify that the serialized version of a shadow
root:
 1. has the `<template shadowroot>` first, before any children,
    regardless of where the initial DSD content put them.
 2. has the various shadowroot* attributes in a well defined order,
    again regardless of where the initial DSD put them.

This came from a comment on the spec PR, here:
 whatwg/html#10139 (comment)

(Note that Github currently doesn't properly handle links to
"Resolved" conversations, and the above conversation is resolved.
So I guess trust me that the request was to add testing for this
case!)

Bug: 41490936
Change-Id: I7866b61b768f645d61142a1fd4a9490ee0732dc2
Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5405665
Reviewed-by: David Baron <dbaron@chromium.org>
Commit-Queue: Mason Freed <masonf@chromium.org>
Auto-Submit: Mason Freed <masonf@chromium.org>
Cr-Commit-Position: refs/heads/main@{#1279973}

--

wpt-commits: 6a072aeb9fcbaa56cab5e168cba7b706268c4d05
wpt-pr: 45415
vinhill pushed a commit to vinhill/dom that referenced this pull request Jun 20, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Development

Successfully merging this pull request may close these issues.

5 participants