RESOLVED FIXED Bug 47233
REGRESSION: Indenting pre duplicates content
https://bugs.webkit.org/show_bug.cgi?id=47233
Summary REGRESSION: Indenting pre duplicates content
Ryosuke Niwa
Reported 2010-10-05 17:41:59 PDT
Reproduction steps: 1. Go to http://www.mozilla.org/editor/midasdemo/ and type in the following in HTML source mode: <pre> hello world </pre> 2. Back to WYSIWYG mode and select all Expected result: <blockquote> <pre> hello world </pre> </blockquote> Actual result: <blockquote class="webkit-indent-blockquote" style="margin: 0 0 0 40px; border: none; padding: 0px;"><pre>hello world </pre><pre>world </pre></blockquote><pre>worl<br>d </pre>
Attachments
fixes the bug (30.52 KB, patch)
2010-10-07 11:29 PDT, Ryosuke Niwa
no flags
fixes the bug; fixed release build (31.08 KB, patch)
2010-10-07 12:51 PDT, Ryosuke Niwa
no flags
fixed per tony's comment (31.13 KB, patch)
2010-10-07 16:07 PDT, Ryosuke Niwa
tony: review+
Tony Chang
Comment 1 2010-10-05 17:50:46 PDT
This is probably a consequence of https://bugs.webkit.org/show_bug.cgi?id=38231, but I'm not sure it's a regression. Previously, we would crash. I'm impressed that we can put a <br> in the middle of a word.
Ryosuke Niwa
Comment 2 2010-10-05 19:30:41 PDT
(In reply to comment #1) > This is probably a consequence of https://bugs.webkit.org/show_bug.cgi?id=38231, but I'm not sure it's a regression. Previously, we would crash. > > I'm impressed that we can put a <br> in the middle of a word. I don't think your patch caused this regression. It's probably mine when I attempted to rewrite IndentOutdentCommand last year. Thanks for the info.
Ryosuke Niwa
Comment 3 2010-10-07 11:29:49 PDT
Created attachment 70125 [details] fixes the bug
Eric Seidel (no email)
Comment 4 2010-10-07 12:00:09 PDT
Ryosuke Niwa
Comment 5 2010-10-07 12:51:12 PDT
Created attachment 70134 [details] fixes the bug; fixed release build
Tony Chang
Comment 6 2010-10-07 15:32:05 PDT
Comment on attachment 70134 [details] fixes the bug; fixed release build View in context: https://bugs.webkit.org/attachment.cgi?id=70134&action=review Overall, this looks great. Using explicit start and end positions is a lot better than passing in the end of a paragraph and using prev/next paragraph. r- because of function naming. > WebCore/ChangeLog:22 > + (WebCore::ApplyBlockElementCommand::rangeForParagraphSplitingTextNodesIfNeeded): Added. Nit: Splitting is spelled wrong. > WebCore/editing/ApplyBlockElementCommand.cpp:151 > +static UChar charAtPosition(const Position& position) Do you plan on check for a char other than '\n'? If not, you could simplify the callers by just making this function isNewlineCharAtPosition. > WebCore/editing/ApplyBlockElementCommand.cpp:213 > + // If start is in the middle of a text node, split. Nit: If *end* is . . . > LayoutTests/editing/execCommand/indent-pre-expected.txt:4 > +CONSOLE MESSAGE: line 41: Wrong end node type: [object HTMLBRElement] > +CONSOLE MESSAGE: line 44: Wrong node selected. Is this change intentional? Would extra tests with <pre> and <table> be useful at this point? Maybe it should just be a follow up patch. > LayoutTests/editing/execCommand/indent-pre-expected.txt:49 > +| "list two" > +| <br> > +| "list three" > +| <br> The additional <br>s look weird, but I guess it's harmless.
Ryosuke Niwa
Comment 7 2010-10-07 16:07:41 PDT
Created attachment 70163 [details] fixed per tony's comment
Ryosuke Niwa
Comment 8 2010-10-07 16:15:42 PDT
(In reply to comment #6) > > WebCore/ChangeLog:22 > > + (WebCore::ApplyBlockElementCommand::rangeForParagraphSplitingTextNodesIfNeeded): Added. > Nit: Splitting is spelled wrong. Oops, fixed. > > WebCore/editing/ApplyBlockElementCommand.cpp:151 > > +static UChar charAtPosition(const Position& position) > > Do you plan on check for a char other than '\n'? If not, you could simplify the callers by just making this function isNewlineCharAtPosition. Good idea. I had the exact function sometime in the past but I had to generalize it to deal with some fix that ended up not being in the final patch. Fixed. > > WebCore/editing/ApplyBlockElementCommand.cpp:213 > > + // If start is in the middle of a text node, split. > > Nit: If *end* is . . . Thanks for noticing that. You can tell my concentration was really low when I added this comment... > > LayoutTests/editing/execCommand/indent-pre-expected.txt:4 > > +CONSOLE MESSAGE: line 41: Wrong end node type: [object HTMLBRElement] > > +CONSOLE MESSAGE: line 44: Wrong node selected. > > Is this change intentional? No but the test claims that we just need not to crash. So I think this is okay. And I think this is related to the following change: > > LayoutTests/editing/execCommand/indent-pre-expected.txt:49 > > +| "list two" > > +| <br> > > +| "list three" > > +| <br> > > The additional <br>s look weird, but I guess it's harmless. Yes. They are visually identical. I believe this is a bug in moveParagraphWithClones for which I know how to fix it. But I'd rather not to add any more fixes into one patch since this is purely cosmetic issue, and new behavior is clearly better than duplicating contents. > Would extra tests with <pre> and <table> be useful at this point? Maybe it should just be a follow up patch. I'm not sure if that'll be useful because we take the same code path. My fix was mainly splitting text nodes and adjusting nodes for moveParagraphWithClones. Table only changes the unsplittable element and I don't think it's relevant to this change. The only reason I added list was to make sure two code paths in IndentOutdentCommand each of which calls moveParagraphWithClones have the test coverage.
Tony Chang
Comment 9 2010-10-07 16:27:46 PDT
Comment on attachment 70163 [details] fixed per tony's comment View in context: https://bugs.webkit.org/attachment.cgi?id=70163&action=review > WebCore/WebCore.xcodeproj/project.pbxproj:-21153 > - developmentRegion = English; Nit: It's probably best to remove this change when committing.
Ryosuke Niwa
Comment 10 2010-10-07 16:55:15 PDT
Tony Chang
Comment 11 2010-10-07 17:26:53 PDT
Comment on attachment 70163 [details] fixed per tony's comment View in context: https://bugs.webkit.org/attachment.cgi?id=70163&action=review > WebCore/editing/ApplyBlockElementCommand.cpp:117 > + Position start; > + Position end; Sorry, I just noticed this: You might want to declare these outside the loop so we don't have to run the constructor/destructor on each loop.
WebKit Review Bot
Comment 12 2010-10-07 18:11:20 PDT
http://trac.webkit.org/changeset/69354 might have broken GTK Linux 32-bit Release
Ryosuke Niwa
Comment 13 2010-10-07 18:25:40 PDT
Thanks for the review, Tony. I can finally fix the 19795!
Ryosuke Niwa
Comment 14 2010-10-07 19:18:15 PDT
(In reply to comment #11) > (From update of attachment 70163 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=70163&action=review > > > WebCore/editing/ApplyBlockElementCommand.cpp:117 > > + Position start; > > + Position end; > > Sorry, I just noticed this: > You might want to declare these outside the loop so we don't have to run the constructor/destructor on each loop. Oops, I missed this comment. I'll fix this in my patch for the bug 19795.
Note You need to log in before you can comment on or make changes to this bug.