Bug 152957

Summary: Get text drawing working with display lists
Product: WebKit Reporter: Simon Fraser (smfr) <simon.fraser>
Component: Layout and RenderingAssignee: zalan <zalan>
Status: RESOLVED FIXED    
Severity: Normal CC: buildbot, mmaxfield, rniwa, simon.fraser, thorton, zalan
Priority: P2    
Version: Safari 9   
Hardware: Unspecified   
OS: Unspecified   
Bug Depends on:    
Bug Blocks: 152808    
Attachments:
Description Flags
Patch
none
Patch
none
Archive of layout-test-results from ews103 for mac-yosemite
none
Patch simon.fraser: review+

Simon Fraser (smfr)
Reported 2016-01-09 22:42:38 PST
Text drawing is stubbed out; need to make it work.
Attachments
Patch (6.86 KB, patch)
2016-01-12 14:18 PST, zalan
no flags
Patch (8.59 KB, patch)
2016-01-12 14:37 PST, zalan
no flags
Archive of layout-test-results from ews103 for mac-yosemite (740.40 KB, application/zip)
2016-01-12 15:30 PST, Build Bot
no flags
Patch (8.59 KB, patch)
2016-01-12 19:31 PST, zalan
simon.fraser: review+
zalan
Comment 1 2016-01-12 14:18:48 PST
zalan
Comment 2 2016-01-12 14:37:56 PST
Said Abou-Hallawa
Comment 3 2016-01-12 15:17:53 PST
Comment on attachment 268812 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=268812&action=review > Source/WebCore/platform/graphics/GraphicsContext.cpp:698 > + fontCascade.drawGlyphs(*this, font, buffer, from, numGlyphs, point, fontCascade.fontDescription().fontSmoothing()); Why is this change? You are making FontCascade::drawGlyphs a static functio , removing the const qualifier and passing a member of a member of FontCascade itself. At the same time all the other functions in FontCascade like drawText() and drawEmphasisMarks() are not static. Should not we be consistent here?
Build Bot
Comment 4 2016-01-12 15:30:21 PST
Comment on attachment 268812 [details] Patch Attachment 268812 [details] did not pass mac-ews (mac): Output: http://webkit-queues.webkit.org/results/684022 New failing tests: fast/picture/image-picture-loads-1x.html
Build Bot
Comment 5 2016-01-12 15:30:23 PST
Created attachment 268819 [details] Archive of layout-test-results from ews103 for mac-yosemite The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: ews103 Port: mac-yosemite Platform: Mac OS X 10.10.5
zalan
Comment 6 2016-01-12 15:32:06 PST
Comment on attachment 268812 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=268812&action=review >> Source/WebCore/platform/graphics/GraphicsContext.cpp:698 >> + fontCascade.drawGlyphs(*this, font, buffer, from, numGlyphs, point, fontCascade.fontDescription().fontSmoothing()); > > Why is this change? You are making FontCascade::drawGlyphs a static functio , removing the const qualifier and passing a member of a member of FontCascade itself. At the same time all the other functions in FontCascade like drawText() and drawEmphasisMarks() are not static. Should not we be consistent here? I am not sure what you mean by consistency. drawText() and drawEmphasisMarks() are both higher level drawing functions. They generate a glyphBuffer and call drawGlyphs() with it.
Said Abou-Hallawa
Comment 7 2016-01-12 15:39:01 PST
Comment on attachment 268812 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=268812&action=review >>> Source/WebCore/platform/graphics/GraphicsContext.cpp:698 >>> + fontCascade.drawGlyphs(*this, font, buffer, from, numGlyphs, point, fontCascade.fontDescription().fontSmoothing()); >> >> Why is this change? You are making FontCascade::drawGlyphs a static functio , removing the const qualifier and passing a member of a member of FontCascade itself. At the same time all the other functions in FontCascade like drawText() and drawEmphasisMarks() are not static. Should not we be consistent here? > > I am not sure what you mean by consistency. drawText() and drawEmphasisMarks() are both higher level drawing functions. They generate a glyphBuffer and call drawGlyphs() with it. I meant the signatures of these functions look similar: WEBCORE_EXPORT float drawText(GraphicsContext&, const TextRun&, const FloatPoint&, int from = 0, int to = -1, CustomFontNotReadyAction = DoNotPaintIfFontNotReady) const; void drawGlyphs(GraphicsContext&, const Font&, const GlyphBuffer&, int from, int numGlyphs, const FloatPoint&) const; void drawEmphasisMarks(GraphicsContext&, const TextRun&, const AtomicString& mark, const FloatPoint&, int from = 0, int to = -1) const; All of them are non static and const. So why did you pick one of them"drawGlyphs" and make it static? And to overcome the problem of using a member of the class "FontCascade::fontDescription()" you are now passing it every time drawGlyphs() is called.
zalan
Comment 8 2016-01-12 16:18:26 PST
(In reply to comment #5) > Created attachment 268819 [details] > Archive of layout-test-results from ews103 for mac-yosemite > > The attached test failures were seen while running run-webkit-tests on the > mac-ews. > Bot: ews103 Port: mac-yosemite Platform: Mac OS X 10.10.5 This failure seems unrelated.
zalan
Comment 9 2016-01-12 19:31:28 PST
zalan
Comment 10 2016-01-12 19:31:41 PST
probe EWS again.
Simon Fraser (smfr)
Comment 11 2016-01-12 20:57:57 PST
Comment on attachment 268844 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=268844&action=review > Source/WebCore/platform/graphics/GraphicsContext.cpp:-689 > - if (isRecording()) { > - // FIXME: Text drawing with display lists TBD. > - return 0; > - } > - I think this needs a comment to say why it doesn't do anything when recording. I assume font.drawText() calls back into GraphicsContext::drawGlyphs? Would be nice to name these so it's obvious which is higher and lower level.
zalan
Comment 12 2016-01-13 10:19:59 PST
Note You need to log in before you can comment on or make changes to this bug.