Bug 208177

Summary: Make Editor::applyEditingStyleToBodyElement do things in a straightforward manner
Product: WebKit Reporter: Darin Adler <darin>
Component: HTML EditingAssignee: Darin Adler <darin>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, ews-watchlist, koivisto, mifenton, rniwa, webkit-bug-importer, wenson_hsieh
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: All   
OS: All   
Attachments:
Description Flags
Patch none

Darin Adler
Reported 2020-02-24 22:42:51 PST
Make Editor::applyEditingStyleToBodyElement do things in a straightforward manner
Attachments
Patch (2.45 KB, patch)
2020-02-24 22:44 PST, Darin Adler
no flags
Darin Adler
Comment 1 2020-02-24 22:44:18 PST
Antti Koivisto
Comment 2 2020-02-25 06:09:25 PST
Comment on attachment 391626 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=391626&action=review > Source/WebCore/editing/Editor.cpp:-3442 > - // Mutate using the CSSOM wrapper so we get the same event behavior as a script. > - auto& style = body->cssomStyle(); This originates from https://bugs.webkit.org/show_bug.cgi?id=78589 and was based on Ryosuke's comments ("In my second thought, not instantiating mutation scope is fine because all calls to setInlineStyleProperty are invisible to scripts except ones in Editor.cpp, RemoveCSSPropertyCommand.cpp, & ReplaceSelectionCommand.cpp. Please revert those before landing the patch.") Has something changed so we don't need this anymore here?
Darin Adler
Comment 3 2020-02-25 12:02:14 PST
Comment on attachment 391626 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=391626&action=review >> Source/WebCore/editing/Editor.cpp:-3442 >> - auto& style = body->cssomStyle(); > > This originates from https://bugs.webkit.org/show_bug.cgi?id=78589 and was based on Ryosuke's comments ("In my second thought, not instantiating mutation scope is fine because all calls to setInlineStyleProperty are invisible to scripts except ones in Editor.cpp, RemoveCSSPropertyCommand.cpp, & ReplaceSelectionCommand.cpp. Please revert those before landing the patch.") > > Has something changed so we don't need this anymore here? The call sites in editing commands (RemoveCSSPropertyCommand, ReplaceSelectionCommand.cpp) are a web-visible part of how editing behaves on webpages. So Ryoskue’s logic makes sense there, although using the CSS object model wrappers seems like a roundabout way to implement it. This function is used for something quite different, a mode switch on the entire web view. I don’t think the mutation event issues are the same, and the most important cases I am aware of, like in the iOS and macOS Mail apps, also disable content scripting. However, there could be something I missed: maybe someone can think of a reason I would need to "instantiate mutation scope" here. I didn’t do that. I think I need advice on how to write a test that can demonstrate why this matters. I’d be willing to do that.
Antti Koivisto
Comment 4 2020-02-25 12:07:19 PST
> This function is used for something quite different, a mode switch on the > entire web view. I don’t think the mutation event issues are the same, and > the most important cases I am aware of, like in the iOS and macOS Mail apps, > also disable content scripting. Ok, maybe I just took the comment too broadly originally and this was never needed in the first place. > However, there could be something I missed: maybe someone can think of a > reason I would need to "instantiate mutation scope" here. I didn’t do that. > > I think I need advice on how to write a test that can demonstrate why this > matters. I’d be willing to do that. Ryosuke might have ideas?
Antti Koivisto
Comment 5 2020-02-25 12:08:42 PST
I'm ok with landing as-is.
Ryosuke Niwa
Comment 6 2020-02-25 13:08:23 PST
Comment on attachment 391626 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=391626&action=review I'm not certain that we want to land this patch. > Source/WebCore/editing/Editor.cpp:-3435 > - // FIXME: Not clear it's valuable to do this to all body elements rather than just doing it on the single one returned by Document::body. Isn't this because we can have multiple body elements in one of those badly written CMS pages?
Darin Adler
Comment 7 2020-02-26 20:03:44 PST
Comment on attachment 391626 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=391626&action=review >> Source/WebCore/editing/Editor.cpp:-3435 >> - // FIXME: Not clear it's valuable to do this to all body elements rather than just doing it on the single one returned by Document::body. > > Isn't this because we can have multiple body elements in one of those badly written CMS pages? Maybe; but when would that intersect with an editable WebView? This isn’t used by web browsers.
Ryosuke Niwa
Comment 8 2020-02-26 21:01:09 PST
(In reply to Darin Adler from comment #7) > Comment on attachment 391626 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=391626&action=review > > >> Source/WebCore/editing/Editor.cpp:-3435 > >> - // FIXME: Not clear it's valuable to do this to all body elements rather than just doing it on the single one returned by Document::body. > > > > Isn't this because we can have multiple body elements in one of those badly written CMS pages? > > Maybe; but when would that intersect with an editable WebView? This isn’t > used by web browsers. Oh, I see. It's probably fine then. I knew we used to have a lot of code dealing with duplicated body elements because ReplaceSelectionCommand / createMarkup used to generate them sometimes but I think we've mostly resolved that problem by now.
Darin Adler
Comment 9 2020-03-05 21:46:07 PST
Having a hard time deciding whether to land this patch or not.
Ryosuke Niwa
Comment 10 2020-03-05 22:42:25 PST
(In reply to Darin Adler from comment #9) > Having a hard time deciding whether to land this patch or not. It seems okay to land this change given it doesn't affect editing commands / general web visible behavior.
Antti Koivisto
Comment 11 2020-03-05 22:43:40 PST
Yeah, go ahead and land.
WebKit Commit Bot
Comment 12 2020-03-07 13:46:29 PST
Comment on attachment 391626 [details] Patch Clearing flags on attachment: 391626 Committed r258077: <https://trac.webkit.org/changeset/258077>
WebKit Commit Bot
Comment 13 2020-03-07 13:46:30 PST
All reviewed patches have been landed. Closing bug.
Radar WebKit Bug Importer
Comment 14 2020-03-07 13:47:12 PST
Note You need to log in before you can comment on or make changes to this bug.