WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
61276
<input type=color> Mac UI behaviour
https://bugs.webkit.org/show_bug.cgi?id=61276
Summary
<input type=color> Mac UI behaviour
Keishi Hattori
Reported
2011-05-23 05:49:46 PDT
Implement the UI behavior for the Mac platform. You should be able to pick a color from a color picker when the user clicks on a color control.
Attachments
test implementation of UI behaviour
(22.52 KB, patch)
2011-05-23 05:57 PDT
,
Keishi Hattori
no flags
Details
Formatted Diff
Diff
Screen recording of patch
(3.48 MB, application/octet-stream)
2011-05-23 06:01 PDT
,
Keishi Hattori
no flags
Details
patch
(48.59 KB, patch)
2011-06-08 23:54 PDT
,
Keishi Hattori
no flags
Details
Formatted Diff
Diff
Patch
(21.73 KB, patch)
2013-06-25 18:23 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Archive of layout-test-results from webkit-ews-05 for mac-mountainlion
(171.11 KB, application/zip)
2013-06-25 22:52 PDT
,
Build Bot
no flags
Details
Archive of layout-test-results from webkit-ews-09 for mac-mountainlion-wk2
(592.40 KB, application/zip)
2013-06-26 06:34 PDT
,
Build Bot
no flags
Details
Patch
(31.85 KB, patch)
2013-07-03 11:24 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(32.72 KB, patch)
2013-07-03 15:40 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(47.31 KB, patch)
2013-07-03 16:01 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(47.04 KB, patch)
2013-07-09 10:17 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(53.48 KB, patch)
2013-07-11 18:34 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(68.84 KB, patch)
2013-07-12 01:36 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(64.31 KB, patch)
2013-07-15 23:41 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(60.76 KB, patch)
2013-07-16 00:49 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(60.53 KB, patch)
2013-07-16 11:07 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(60.97 KB, patch)
2013-07-16 16:16 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(63.35 KB, patch)
2013-07-16 23:10 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Archive of layout-test-results from webkit-ews-07 for mac-mountainlion
(574.29 KB, application/zip)
2013-07-17 04:04 PDT
,
Build Bot
no flags
Details
Patch
(63.45 KB, patch)
2013-07-17 09:36 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(64.13 KB, patch)
2013-07-17 12:28 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(64.78 KB, patch)
2013-07-17 13:57 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Archive of layout-test-results from webkit-ews-06 for mac-mountainlion
(816.12 KB, application/zip)
2013-07-17 17:44 PDT
,
Build Bot
no flags
Details
Patch
(66.38 KB, patch)
2013-07-19 14:11 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(66.09 KB, patch)
2013-07-19 15:48 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(63.97 KB, patch)
2013-07-22 11:39 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(70.31 KB, patch)
2013-07-25 11:42 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(70.37 KB, patch)
2013-07-25 17:07 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(70.02 KB, patch)
2013-07-30 22:41 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Patch
(69.97 KB, patch)
2013-07-31 10:24 PDT
,
Ruth Fong
no flags
Details
Formatted Diff
Diff
Show Obsolete
(23)
View All
Add attachment
proposed patch, testcase, etc.
Keishi Hattori
Comment 1
2011-05-23 05:57:13 PDT
Created
attachment 94407
[details]
test implementation of UI behaviour
Keishi Hattori
Comment 2
2011-05-23 05:57:56 PDT
(In reply to
comment #1
)
> Created an attachment (id=94407) [details] > test implementation of UI behaviour
Patch needs to be applied after the patch from
Bug 61275
.
Keishi Hattori
Comment 3
2011-05-23 06:01:50 PDT
Created
attachment 94409
[details]
Screen recording of patch
Keishi Hattori
Comment 4
2011-06-08 23:54:49 PDT
Created
attachment 96554
[details]
patch
Kent Tamura
Comment 5
2011-06-09 00:28:24 PDT
Comment on
attachment 96554
[details]
patch I recommend you split the patch into - sort Xcode project (it doesn't need review) - WebCore part - WebKit(2)/mac part
Radar WebKit Bug Importer
Comment 6
2011-10-11 16:54:48 PDT
<
rdar://problem/10269922
>
Ruth Fong
Comment 7
2013-06-25 18:23:17 PDT
Created
attachment 205435
[details]
Patch
Build Bot
Comment 8
2013-06-25 22:52:43 PDT
Comment on
attachment 205435
[details]
Patch
Attachment 205435
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.appspot.com/results/944202
New failing tests: compositing/geometry/bounds-clipped-composited-child.html compositing/contents-opaque/body-background-painted.html compositing/contents-opaque/overflow-hidden-child-layers.html compositing/geometry/bounds-ignores-hidden-composited-descendant.html compositing/framesets/composited-frame-alignment.html compositing/backing/no-backing-for-clip-overlap.html compositing/filters/sw-shadow-overlaps-hw-shadow.html compositing/contents-opaque/background-color.html compositing/contents-opaque/layer-transform.html compositing/iframes/become-overlapped-iframe.html compositing/filters/sw-shadow-overlaps-hw-layer.html compositing/animation/animation-compositing.html compositing/contents-opaque/hidden-with-visible-child.html compositing/backing/no-backing-for-clip.html compositing/filters/sw-layer-overlaps-hw-shadow.html compositing/geometry/ancestor-overflow-change.html compositing/contents-opaque/filter.html compositing/geometry/bounds-ignores-hidden-dynamic-negzindex.html compositing/columns/composited-in-paginated.html compositing/iframes/become-composited-nested-iframes.html compositing/contents-opaque/hidden-with-visible-text.html compositing/contents-opaque/layer-opacity.html compositing/contents-opaque/body-background-skipped.html compositing/contents-opaque/background-clip.html compositing/iframes/composited-parent-iframe.html compositing/contents-opaque/visibility-hidden.html compositing/backing/no-backing-for-clip-overhang.html compositing/backing/no-backing-for-perspective.html compositing/contents-opaque/control-layer.html compositing/filters/sw-nested-shadow-overlaps-hw-nested-shadow.html
Build Bot
Comment 9
2013-06-25 22:52:46 PDT
Created
attachment 205450
[details]
Archive of layout-test-results from webkit-ews-05 for mac-mountainlion The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: webkit-ews-05 Port: mac-mountainlion Platform: Mac OS X 10.8.3
Build Bot
Comment 10
2013-06-26 06:34:40 PDT
Comment on
attachment 205435
[details]
Patch
Attachment 205435
[details]
did not pass mac-wk2-ews (mac-wk2): Output:
http://webkit-queues.appspot.com/results/916653
New failing tests: platform/mac/accessibility/role-subrole-roledescription.html accessibility/color-well.html
Build Bot
Comment 11
2013-06-26 06:34:43 PDT
Created
attachment 205484
[details]
Archive of layout-test-results from webkit-ews-09 for mac-mountainlion-wk2 The attached test failures were seen while running run-webkit-tests on the mac-wk2-ews. Bot: webkit-ews-09 Port: mac-mountainlion-wk2 Platform: Mac OS X 10.8.3
Ruth Fong
Comment 12
2013-07-03 11:24:12 PDT
Created
attachment 206014
[details]
Patch
Ruth Fong
Comment 13
2013-07-03 15:40:00 PDT
Created
attachment 206031
[details]
Patch
Ruth Fong
Comment 14
2013-07-03 16:01:16 PDT
Created
attachment 206032
[details]
Patch include color tests on Mac platform
Build Bot
Comment 15
2013-07-05 06:51:03 PDT
Comment on
attachment 206032
[details]
Patch
Attachment 206032
[details]
did not pass win-ews (win): Output:
http://webkit-queues.appspot.com/results/991372
Jon Lee
Comment 16
2013-07-08 13:26:21 PDT
Comment on
attachment 206032
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206032&action=review
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:63 > + static WebColorChooserProxyMac* open(WebColorChooserProxy::Client*, const WebCore::Color&);
If this is only called from create(), this should be private.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:64 > + WebColorChooserProxyMac(WebColorChooserProxy::Client*, const WebCore::Color&);
Given open() is the only function calling the constructor, you should make it private.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:85 > + BOOL _nonUserChange;
The naming of this is awkward. I think it would be better to track whether the change was from the user rather than the opposite. _lastChangedByUser, perhaps?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:93 > +- (void)didChooseColor:(NSColorPanel*)panel;
(NSColorPanel *) (see later comment)
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:96 > +- (void)setColor:(NSColor*)color;
ditto
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:61 > +: WebColorChooserProxy(client)
Missing indentation.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:66 > + [[NSColorPanel sharedColorPanel] makeKeyAndOrderFront:nil];
I think it makes more sense for the shared color panel management to all happen through the WKColorPanelCocoa class rather than doing it here. That way all interaction with NSColorPanel happens via that class.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:72 > + if (m_client) {
It might be better to do the reverse check here, and return early, so that most of the code in this function isn't overly-indented. You already do this in other functions.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:73 > + ASSERT(color != nullptr);
This assert doesn't make sense.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:74 > + ASSERT(m_client);
This assert doesn't make sense.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:111 > + NSColorPanel* panel = [NSColorPanel sharedColorPanel];
Cocoa style dictates "NSColorPanel *panel" not "NSColorPanel* panel"
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:121 > + NSColorPanel* panel = [NSColorPanel sharedColorPanel];
Ditto.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:131 > +- (void)windowWillClose:(NSNotification*)notification {
Ditto.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:136 > +- (void)didChooseColor:(NSColorPanel*)panel {
Ditto.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:146 > +- (void)setColor:(NSColor*)color {
Ditto.
Ruth Fong
Comment 17
2013-07-09 10:17:08 PDT
Created
attachment 206336
[details]
Patch
Ruth Fong
Comment 18
2013-07-11 16:33:00 PDT
The most recent patch does not support a page with more than one <input type='color'> element (the current patch handles <input type='color'> across multiple processes fine though). This is because at WebChromeClient::createColorChooser, we're returning a nullptr if there's already an activeColorChooser. This is a bit more complicated than deleting that if-clause because WebColorChooserProxyMac::create first destroys its singleton object if it's already been created, setting a cascade down the stack to destroy the WebColorChooser m_activeColorChooser object in WebPage. My current approach is to not create a new WebColorChooser for every <input type='color'> on a webpage but to reuse it for a given process (since there's only going to be one color picker displayed at a time). In ColorInputType::handleDOMActivateEvent, if m_chooser has already been initialized, I'll call a new method like resetChooser(color) to use the color picker for the second <input type='color'> element. This avoids the unnecessary climb up and down the stack to create a new color picker and destroy the old one. This patch will be uploaded for review soon.
Ruth Fong
Comment 19
2013-07-11 18:34:15 PDT
Created
attachment 206501
[details]
Patch still need to break association between color well and color picker when the user leaves the page
Tim Horton
Comment 20
2013-07-11 18:50:51 PDT
Comment on
attachment 206501
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206501&action=review
very very brief first pass looking at small things and not the whole-picture architecture
> Source/WebCore/ChangeLog:11 > +
This needs sooooooo many more words.
> Source/WebKit2/ChangeLog:46 > + WKColorPanelCocoa is a wrapper for a NSColorPanel object
"Mac", I think? Unless there's precedence.
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2970 > + // FIXME: Where is this colorPickerResultListener code being used?
Should probably figure out what's going on here.
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2999 > + m_colorChooser->resetColorChooser(color);
Why does "reset" take a color? What does reset do? Is reset actually "reattach"?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:53 > +class WebColorChooserProxy;
Don't need this. Already including WebColorChooserProxy.h above.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:74 > +@interface WKColorPanelCocoa : NSObject<NSWindowDelegate> {
Still voting for WKColorPanelMac.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:81 > +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac *)chooser WithColor:(NSColor *)color;
The first star is on the wrong side (left for C++ objects, right for ObjC).
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:43 > +//WebColorChooserProxyMac* WebColorChooserProxyMac::s_currentColorChooser;
Please don't add commented out code.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:97 > +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser WithColor:(NSColor *)color {
First { on next line even for ObjC methods, as far as I remember. There are a bunch of these in the patch.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:105 > + [self setColor: color];
no space after the colon. Mitz used to tell me to use dot notation for simple properties but people keep changing their mind so I don't really know.
Tim Horton
Comment 21
2013-07-11 18:51:37 PDT
(In reply to
comment #19
)
> still need to break association between color well and color picker when the user leaves the page
Also IIRC the color well doesn't stay highlighted when it's active?
EFL EWS Bot
Comment 22
2013-07-11 18:52:24 PDT
Comment on
attachment 206501
[details]
Patch
Attachment 206501
[details]
did not pass efl-wk2-ews (efl-wk2): Output:
http://webkit-queues.appspot.com/results/899676
Early Warning System Bot
Comment 23
2013-07-11 18:56:56 PDT
Comment on
attachment 206501
[details]
Patch
Attachment 206501
[details]
did not pass qt-wk2-ews (qt-wk2): Output:
http://webkit-queues.appspot.com/results/899673
Build Bot
Comment 24
2013-07-11 19:18:05 PDT
Comment on
attachment 206501
[details]
Patch
Attachment 206501
[details]
did not pass mac-wk2-ews (mac-wk2): Output:
http://webkit-queues.appspot.com/results/931650
Build Bot
Comment 25
2013-07-11 19:42:53 PDT
Comment on
attachment 206501
[details]
Patch
Attachment 206501
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.appspot.com/results/971838
Build Bot
Comment 26
2013-07-11 20:43:00 PDT
Comment on
attachment 206501
[details]
Patch
Attachment 206501
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.appspot.com/results/1054151
Ruth Fong
Comment 27
2013-07-11 21:05:15 PDT
Comment on
attachment 206501
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206501&action=review
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2999 >> + m_colorChooser->resetColorChooser(color); > > Why does "reset" take a color? What does reset do? Is reset actually "reattach"?
Reset is reattach. Will rename.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:74 >> +@interface WKColorPanelCocoa : NSObject<NSWindowDelegate> { > > Still voting for WKColorPanelMac.
Yup - will rename.
Jon Lee
Comment 28
2013-07-11 22:01:23 PDT
Comment on
attachment 206501
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206501&action=review
> Source/JavaScriptCore/ChangeLog:9 > + * Configurations/FeatureDefines.xcconfig:
Please include a brief description of what's happening here.
> Source/WTF/ChangeLog:9 > + * wtf/FeatureDefines.h:
Please include a brief description of what's happening here.
> Source/WebCore/ChangeLog:10 > + <input type='color'> objects.
I assume this will be taken care of in a future patch. You won't be able to check anything if the changelogs contain "OOPS!".
> Source/WebCore/html/ColorInputType.cpp:154 > + if (chrome) {
Now that |chrome| has been isolated in the conditional, and it is only used within the if block, you could merge the above two lines as: if (Chrome* chrome = this->chrome()) { ...
> Source/WebCore/html/ColorInputType.cpp:158 > + m_chooser->resetColorChooser(valueAsColor());
This code doesn't make sense to me on first blush. I understand there are side effects happening, but I had to comb through the whole logic to get there. Ideally you'd be seeing something more like: if (!m_chooser) m_chooser = chrome->createColorChooser(this); m_chooser->setColorChooser(valueAsColor()); where setColorChooser() implies connecting the web page to the UI. Would it possible to do this without wreaking havoc on the other ports?
>> Source/WebKit2/ChangeLog:46 >> + WKColorPanelCocoa is a wrapper for a NSColorPanel object > > "Mac", I think? Unless there's precedence.
+1
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2970 >> + // FIXME: Where is this colorPickerResultListener code being used? > > Should probably figure out what's going on here.
You should do a grep on the other ports. If this is not needed for Macs, we should hide this in a PLATFORM #ifdef.
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2978 > + m_colorChooser = WebColorChooserProxy::create(this);
I'm confused by this code. Why are we creating a chooser proxy here, and then also if the UI client fails to show the color picker a few lines later?
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2995 > +void WebPageProxy::resetColorChooser(const WebCore::Color& color)
Looks like you need to provide stub impls of these for other ports.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:97 >> +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser WithColor:(NSColor *)color { > > First { on next line even for ObjC methods, as far as I remember. There are a bunch of these in the patch.
Coding guidelines would make it -initWithChooser:withColor: not WithColor:.
> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:-666 > -
This is very strange code to have in here. In general I'm not a big fan of the side effects I'm seeing built into the constructors.
> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:74 > + m_page->setActiveColorChooser(this);
Are you guaranteed that m_page is not null?
> Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:57 > +#include <WebCore/ColorChooser.h>
#import, please.
Ruth Fong
Comment 29
2013-07-12 00:33:35 PDT
Comment on
attachment 206501
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206501&action=review
>> Source/WebCore/html/ColorInputType.cpp:158 >> + m_chooser->resetColorChooser(valueAsColor()); > > This code doesn't make sense to me on first blush. I understand there are side effects happening, but I had to comb through the whole logic to get there. > > Ideally you'd be seeing something more like: > > if (!m_chooser) > m_chooser = chrome->createColorChooser(this); > m_chooser->setColorChooser(valueAsColor()); > > where setColorChooser() implies connecting the web page to the UI. Would it possible to do this without wreaking havoc on the other ports?
Yes. I can use the setSelectedColor method and make WebColorChooserProxyMac::setSelectedColor do the work that WebColorChooserProxyMac::resetColorChooser is currently doing, but WebColorChooserProxyMac::setSelectedColor is meant to be called from the UI: WKColorPanelMac::didChooseColor, not from the other end of the stack. It would cause a little redundancy in code execution when a color is being selected in a normal situation, as WebColorChooserProxyMac::setSelectedColor will unnecessarily call WKColorPanelMac::setColor. It's definitely do-able though (that's how I first implemented it actually).
>>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2970 >>> + // FIXME: Where is this colorPickerResultListener code being used? >> >> Should probably figure out what's going on here. > > You should do a grep on the other ports. If this is not needed for Macs, we should hide this in a PLATFORM #ifdef.
Got it. Will grep. It's not needed for mac.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2978 >> + m_colorChooser = WebColorChooserProxy::create(this); > > I'm confused by this code. Why are we creating a chooser proxy here, and then also if the UI client fails to show the color picker a few lines later?
This if statement is because I removed the ASSERT. Originally, showColorChooser was only supposed to be called if m_colorChooser was null (this is no longer the case as I'm letting WebColorChooser live as long as ColorInputType). This should be solved by preprocessing wrapping.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:-666 >> - > > This is very strange code to have in here. In general I'm not a big fan of the side effects I'm seeing built into the constructors.
Are you referring to the lines above or the line below? (the lines above were removed)
>> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:74 >> + m_page->setActiveColorChooser(this); > > Are you guaranteed that m_page is not null?
No, but I don't think there should be a real case when m_page is null and resetColorChooser is called, because it's only called when an <input type='color'> element is clicked on for a non-first time, and the WebColorChooser is owned by ColorInputType and lives as long as the input does. Will add an assert.
>> Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:57 >> +#include <WebCore/ColorChooser.h> > > #import, please.
Got it.
Ruth Fong
Comment 30
2013-07-12 00:33:37 PDT
Comment on
attachment 206501
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206501&action=review
>> Source/WebCore/html/ColorInputType.cpp:158 >> + m_chooser->resetColorChooser(valueAsColor()); > > This code doesn't make sense to me on first blush. I understand there are side effects happening, but I had to comb through the whole logic to get there. > > Ideally you'd be seeing something more like: > > if (!m_chooser) > m_chooser = chrome->createColorChooser(this); > m_chooser->setColorChooser(valueAsColor()); > > where setColorChooser() implies connecting the web page to the UI. Would it possible to do this without wreaking havoc on the other ports?
Yes. I can use the setSelectedColor method and make WebColorChooserProxyMac::setSelectedColor do the work that WebColorChooserProxyMac::resetColorChooser is currently doing, but WebColorChooserProxyMac::setSelectedColor is meant to be called from the UI: WKColorPanelMac::didChooseColor, not from the other end of the stack. It would cause a little redundancy in code execution when a color is being selected in a normal situation, as WebColorChooserProxyMac::setSelectedColor will unnecessarily call WKColorPanelMac::setColor. It's definitely do-able though (that's how I first implemented it actually).
>>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2970 >>> + // FIXME: Where is this colorPickerResultListener code being used? >> >> Should probably figure out what's going on here. > > You should do a grep on the other ports. If this is not needed for Macs, we should hide this in a PLATFORM #ifdef.
Got it. Will grep. It's not needed for mac.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2978 >> + m_colorChooser = WebColorChooserProxy::create(this); > > I'm confused by this code. Why are we creating a chooser proxy here, and then also if the UI client fails to show the color picker a few lines later?
This if statement is because I removed the ASSERT. Originally, showColorChooser was only supposed to be called if m_colorChooser was null (this is no longer the case as I'm letting WebColorChooser live as long as ColorInputType). This should be solved by preprocessing wrapping.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:-666 >> - > > This is very strange code to have in here. In general I'm not a big fan of the side effects I'm seeing built into the constructors.
Are you referring to the lines above or the line below? (the lines above were removed)
>> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:74 >> + m_page->setActiveColorChooser(this); > > Are you guaranteed that m_page is not null?
No, but I don't think there should be a real case when m_page is null and resetColorChooser is called, because it's only called when an <input type='color'> element is clicked on for a non-first time, and the WebColorChooser is owned by ColorInputType and lives as long as the input does. Will add an assert.
>> Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:57 >> +#include <WebCore/ColorChooser.h> > > #import, please.
Got it.
Ruth Fong
Comment 31
2013-07-12 01:36:43 PDT
Created
attachment 206514
[details]
Patch using setSelectedColor instead of the previous addition of resetColorChooser; still need to fix disassociating picker upon moving away from the webpage/to another webpage
Sam Weinig
Comment 32
2013-07-12 09:58:30 PDT
Comment on
attachment 206514
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206514&action=review
> Source/WebKit2/UIProcess/WebPageProxy.cpp:582 > + m_colorChooser->endChooser(); > m_colorChooser->invalidate();
Should invalidate just implicitly endChooser()? If not, why not?
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2974 > #if ENABLE(INPUT_TYPE_COLOR) > void WebPageProxy::showColorChooser(const WebCore::Color& initialColor, const IntRect& elementRect) > { > +#if PLATFORM(MAC) > + m_colorChooser = m_pageClient->createColorChooserProxy(this, initialColor, elementRect); > +#else > ASSERT(!m_colorChooser); >
Why is this mac specific? We should really try to keep the platform differences to a minimum at this layer.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:86 > +// A Listener class to act as a event target for NSColorPanel and send > +// the results to the C++ class, WebColorChooserProxyMac. > +@interface WKColorPanelMac : NSObject<NSWindowDelegate> { > + > +@private > + BOOL _lastChangedByUser; > + WebKit::WebColorChooserProxyMac* _chooser; > +} > + > +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser withColor:(NSColor *)color; > + > +- (void)didChooseColor:(NSColorPanel *)panel; > + > +// Sets color to the NSColorPanel as a non user change. > +- (void)setColor:(NSColor *)color; > + > +@end > +
Does this need to be in the header?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:52 > +WebColorChooserProxyMac::~WebColorChooserProxyMac() > +{ > + if (m_panel) > + endChooser(); > +}
The destructor should come after the constructor.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:58 > +WebColorChooserProxyMac::WebColorChooserProxyMac(WebColorChooserProxy::Client* client, const WebCore::Color& initialColor) > + : WebColorChooserProxy(client) > +{ > + m_panel = adoptNS([[WKColorPanelMac alloc] initWithChooser:this withColor:nsColor(initialColor)]); > +}
can the initialization of m_panel be in the initializer list?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:63 > + if (m_panel) > + m_panel = nullptr;
This branch seems unnecessary.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:91 > + if ((self = [super init])) { > + _chooser = chooser;
We traditionally use the early return form of this.
> Source/WebKit2/WebKit2.xcodeproj/project.pbxproj:2506 > + BCBD38FA125BAB9A00D2C29F /* WebPageProxy.messages.in */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; lineEnding = 0; path = WebPageProxy.messages.in; sourceTree = "<group>"; }; > + BCBD3912125BB1A800D2C29F /* WebPageProxyMessageReceiver.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; lineEnding = 0; path = WebPageProxyMessageReceiver.cpp; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.cpp; }; > + BCBD3913125BB1A800D2C29F /* WebPageProxyMessages.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; lineEnding = 0; path = WebPageProxyMessages.h; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.objcpp; };
These seem like unrelated changes.
> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:-665 > - if (m_page->activeColorChooser()) > - return nullptr;
Are you sure others are not relying on this?
Ruth Fong
Comment 33
2013-07-12 10:25:35 PDT
Comment on
attachment 206514
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206514&action=review
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:582 >> m_colorChooser->invalidate(); > > Should invalidate just implicitly endChooser()? If not, why not?
Yep, it should.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2974 >> > > Why is this mac specific? We should really try to keep the platform differences to a minimum at this layer.
It's really because the Mac port doesn't use the stuff in the else statement. Before, INPUT_TYPE_COLOR was off for Mac. Also, earlier, the assumption was that showColorChooser would only be called when m_colorChooser is null. This is no longer the case.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:86 >> + > > Does this need to be in the header?
It can be included in the implementation file, but I figured it'd be better to follow the pattern for C++ in separating the implementation and definitions.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:52 >> +} > > The destructor should come after the constructor.
Got it.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:58 >> +} > > can the initialization of m_panel be in the initializer list?
I'm not sure since it's a Objective-C object.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:63 >> + m_panel = nullptr; > > This branch seems unnecessary.
Got it.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:91 >> + _chooser = chooser; > > We traditionally use the early return form of this.
Got it.
>> Source/WebKit2/WebKit2.xcodeproj/project.pbxproj:2506 >> + BCBD3913125BB1A800D2C29F /* WebPageProxyMessages.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; lineEnding = 0; path = WebPageProxyMessages.h; sourceTree = "<group>"; xcLanguageSpecificationIdentifier = xcode.lang.objcpp; }; > > These seem like unrelated changes.
This may be because I'm building on Lion and on a different version of Xcode.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:-665 >> - return nullptr; > > Are you sure others are not relying on this?
Not sure; will grep and wrap preprocessing in the meantime.
Ruth Fong
Comment 34
2013-07-15 21:42:18 PDT
Comment on
attachment 206501
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206501&action=review
>>>> Source/WebCore/html/ColorInputType.cpp:158 >>>> + m_chooser->resetColorChooser(valueAsColor()); >>> >>> This code doesn't make sense to me on first blush. I understand there are side effects happening, but I had to comb through the whole logic to get there. >>> >>> Ideally you'd be seeing something more like: >>> >>> if (!m_chooser) >>> m_chooser = chrome->createColorChooser(this); >>> m_chooser->setColorChooser(valueAsColor()); >>> >>> where setColorChooser() implies connecting the web page to the UI. Would it possible to do this without wreaking havoc on the other ports? >> >> Yes. I can use the setSelectedColor method and make WebColorChooserProxyMac::setSelectedColor do the work that WebColorChooserProxyMac::resetColorChooser is currently doing, but WebColorChooserProxyMac::setSelectedColor is meant to be called from the UI: WKColorPanelMac::didChooseColor, not from the other end of the stack. It would cause a little redundancy in code execution when a color is being selected in a normal situation, as WebColorChooserProxyMac::setSelectedColor will unnecessarily call WKColorPanelMac::setColor. >> >> It's definitely do-able though (that's how I first implemented it actually). > > Yes. I can use the setSelectedColor method and make WebColorChooserProxyMac::setSelectedColor do the work that WebColorChooserProxyMac::resetColorChooser is currently doing, but WebColorChooserProxyMac::setSelectedColor is meant to be called from the UI: WKColorPanelMac::didChooseColor, not from the other end of the stack. It would cause a little redundancy in code execution when a color is being selected in a normal situation, as WebColorChooserProxyMac::setSelectedColor will unnecessarily call WKColorPanelMac::setColor. > > It's definitely do-able though (that's how I first implemented it actually).
Actually, I'm pretty sure we need to introduce the new API resetColorChooser to reset the color picker's to the current <input type='color'> element (i.e. we will need to call [panel setTarget:self] again from the current WebColorChooserProxyMac object). Will upload a new patch that fixes some of the problems associating to having multiple <input type='color'> elements across multiple tabs.
Ruth Fong
Comment 35
2013-07-15 23:41:36 PDT
Created
attachment 206727
[details]
Patch patch provides correct behavior for multiple color elements on a page and in multiple tabs
Ruth Fong
Comment 36
2013-07-16 00:49:58 PDT
Created
attachment 206734
[details]
Patch merged conflicts with trunk
Jon Lee
Comment 37
2013-07-16 02:27:26 PDT
Comment on
attachment 206734
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206734&action=review
Overall, looks good. Unofficial r=me.
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2973 > + else // handles the case where a color picker already exists for the web process.
Nit: this is a little strange in terms of style; it's not something I've generally seen in the code base. I would suggest pushing the comment into the else clause and wrapping it in braces instead.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:79 > +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac *)chooser withColor:(NSColor*)color;
Style fix: - (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser withColor:(NSColor *)color;
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:81 > +- (void)didChooseColor:(NSColorPanel*)panel;
Ditto.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:84 > +- (void)setColor:(NSColor*)color;
Ditto.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:78 > + m_panel = [[WKColorPanelMac alloc] initWithChooser:this withColor:nsColor(color)];
This is missing an adoptNS(), causing a leak, right?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:82 > + [m_panel initWithChooser:this withColor:nsColor(color)];
This is, I believe, a bit non-standard? Would it be better to refactor the needed code out to another method?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:89 > +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac *)chooser withColor:(NSColor*)color
Spacing is the other way around! - (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser withColor:(NSColor *)color
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:118 > +- (void)windowWillClose:(NSNotification*)notification
Please conform to Cocoa style. (NSNotification *)
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:124 > +- (void)didChooseColor:(NSColorPanel*)panel
Ditto.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:135 > +- (void)setColor:(NSColor*)color
Ditto.
Ruth Fong
Comment 38
2013-07-16 10:06:19 PDT
Comment on
attachment 206734
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206734&action=review
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2973 >> + else // handles the case where a color picker already exists for the web process. > > Nit: this is a little strange in terms of style; it's not something I've generally seen in the code base. > > I would suggest pushing the comment into the else clause and wrapping it in braces instead.
Got it.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:79 >> +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac *)chooser withColor:(NSColor*)color; > > Style fix: > - (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser withColor:(NSColor *)color;
Ah yes; reversed it.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:78 >> + m_panel = [[WKColorPanelMac alloc] initWithChooser:this withColor:nsColor(color)]; > > This is missing an adoptNS(), causing a leak, right?
Yes.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:82 >> + [m_panel initWithChooser:this withColor:nsColor(color)]; > > This is, I believe, a bit non-standard? Would it be better to refactor the needed code out to another method?
Yeah, I think it's a bit non-standard; can factor out half of initWithChooser: withColor: to a new method setWithChooser: withColor.
Ruth Fong
Comment 39
2013-07-16 10:25:31 PDT
Comment on
attachment 206734
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206734&action=review
>>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:82 >>> + [m_panel initWithChooser:this withColor:nsColor(color)]; >> >> This is, I believe, a bit non-standard? Would it be better to refactor the needed code out to another method? > > Yeah, I think it's a bit non-standard; can factor out half of initWithChooser: withColor: to a new method setWithChooser: withColor.
Actually, I think it shouldn't be refactored because there's two kinds of "reattachment" that can occur and I don't know if it's worthwhile to distinguish between the two here (we can distinguish them in initWithChooser: withColor by checking whether or not the color panel is displayed, [NSColorPanel sharedColorPanelExists]). The first one is when there's a UI color picker already living on another tab and you need to reattach it to an <input type='color'> element on your first tab. In that case, you only need to reset 1) the _chooser object 2) the panel's target 3) the panel's color. The second case is when the UI color picker was closed out of another tab, but you return to your first tab that had already had an m_panel instantiated for it. Because the color picker's been destroyed, it needs to be fully initialized again (i.e. all of initWithChooser: withColor).
Ruth Fong
Comment 40
2013-07-16 11:07:17 PDT
Created
attachment 206798
[details]
Patch fixed style issues
Ruth Fong
Comment 41
2013-07-16 16:16:26 PDT
Created
attachment 206823
[details]
Patch with hack fix for disassociating color picker when navigating away from the page
Ruth Fong
Comment 42
2013-07-16 16:23:39 PDT
Comment on
attachment 206823
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206823&action=review
> Source/WebKit2/UIProcess/WebPageProxy.cpp:4521 > + endColorChooser();
This hack disassociates the color picker once the webpage with the color element is navigated away from. Currently, because WebKit caches forwardback history, if a webpage with a color picker associated is navigated away from and then returned to, the color picker is still associated to it. Sam suggested making it an ActiveDOMObject, which is suspended during caching; however, there's no precedence for an input element to be inherit from ActiveDOMObject, and the ColorInputType element doesn't have access to a ScriptExecutionContext object (i.e. the Document object), which is required to construct an ActiveDOMObject. Will look more into better ways to do this using ActiveDOMObject, but Beth suggested to add a FIXME for the issue for now.
Ruth Fong
Comment 43
2013-07-16 23:10:32 PDT
Created
attachment 206858
[details]
Patch detaches color picker when caching page and wraps reattachColorChooser pathway in Mac preprocessing; still a bug where when a page is loaded from cache, sometimes the initial colors are off
Build Bot
Comment 44
2013-07-17 04:04:26 PDT
Comment on
attachment 206858
[details]
Patch
Attachment 206858
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.appspot.com/results/1101126
New failing tests: fullscreen/full-screen-iframe-with-max-width-height.html
Build Bot
Comment 45
2013-07-17 04:04:31 PDT
Created
attachment 206879
[details]
Archive of layout-test-results from webkit-ews-07 for mac-mountainlion The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: webkit-ews-07 Port: mac-mountainlion Platform: Mac OS X 10.8.3
Ruth Fong
Comment 46
2013-07-17 09:36:05 PDT
Created
attachment 206892
[details]
Patch fixed bug breaking the gtk build in webpageproxy.messages.in to include ReattachColorChooser only on Mac and when INPUT_TYPE_COLOR is enabled
Ruth Fong
Comment 47
2013-07-17 12:28:46 PDT
Created
attachment 206906
[details]
Patch fixed bug where the first click in the color picker associated to a second color element wouldn't change the value of that color element, and fixed bug so that when javascript is used to change the value of a color element while the color picker is opened, the new color is displayed in the color picker
Ruth Fong
Comment 48
2013-07-17 13:05:55 PDT
(In reply to
comment #47
)
> Created an attachment (id=206906) [details] > Patch > > fixed bug where the first click in the color picker associated to a second color element wouldn't change the value of that color element, and fixed bug so that when javascript is used to change the value of a color element while the color picker is opened, the new color is displayed in the color picker
Before this patch, there's a side effect that sometimes happens when there's more than one <input type='color'> element on a page. When we click in one color well, and then click in a second color well and select a different color in the color picker, the <input type='color'> value won't change on that click. However, when you click again in the color picker, the <input type='color'> value changes as expected. This is because in WebColorChooserProxyMac::didChooseColor, the if-clause is hit and the early return taken on that first click in the second well. This is because [self setColor:initialColor] is called in initWithChooser, which sets _lastChangedByUser to YES. Because [NSColorPanel sharedColorPanel]'s action is set to didChooseColor, the expected action should be then that didChooseColor is called after setColor, which would set _lastChangedByUser to NO. For some reason, there was a lag behind the didChooseColor that should be called due to switching color wells and instead the didChooseColor from the first click in the color picker is executed first, which is why the color picked is never communicated back to the <input type='color'> element. Probably in another bug, we should test that JavaScript changes to an <input type='color'>'s value sends off the right events and changes the color in an open color picker correctly. Currently, when a color element's value is changed using JavaScript, the change event is not fired. in ColorInputType::setValue, the TextFieldEventBehavior when it's called in this case is a DispatchNoEvent.
Ruth Fong
Comment 49
2013-07-17 13:57:22 PDT
Created
attachment 206909
[details]
Patch fixed bug so that color elements will be loaded from page cache as the last value chosen before caching
Build Bot
Comment 50
2013-07-17 17:44:41 PDT
Comment on
attachment 206909
[details]
Patch
Attachment 206909
[details]
did not pass mac-ews (mac): Output:
http://webkit-queues.appspot.com/results/1103338
New failing tests: svg/batik/text/smallFonts.svg
Build Bot
Comment 51
2013-07-17 17:44:45 PDT
Created
attachment 206937
[details]
Archive of layout-test-results from webkit-ews-06 for mac-mountainlion The attached test failures were seen while running run-webkit-tests on the mac-ews. Bot: webkit-ews-06 Port: mac-mountainlion Platform: Mac OS X 10.8.3
Build Bot
Comment 52
2013-07-17 21:25:54 PDT
Comment on
attachment 206909
[details]
Patch
Attachment 206909
[details]
did not pass win-ews (win): Output:
http://webkit-queues.appspot.com/results/1097386
Jon Lee
Comment 53
2013-07-18 18:40:13 PDT
Comment on
attachment 206909
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206909&action=review
Please fix the windows builder.
> Source/WebCore/html/HTMLInputElement.cpp:1975 > +#if ENABLE(INPUT_TYPE_COLOR) && PLATFORM(MAC)
The ENABLE should move to encompass the whole function.
> Source/WebCore/html/HTMLInputElement.h:305 > + virtual void documentWillSuspendForPageCache() OVERRIDE;
This ought to be wrapped in an ENABLE.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:87 > + // handle the case where the color picker has been closed for an <input type='color'> element.
nit: capital-H please
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:142 > + if (_lastChangedByUser) {
What is the reason for this check? Can this be called by something else other than the color panel when the user chooses a color?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:148 > + _lastChangedByUser = NO;
This is redundant.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:153 > + _lastChangedByUser = YES;
The booleans I think are consistent with the last name for this variable. They should be reversed.
Ruth Fong
Comment 54
2013-07-18 20:09:01 PDT
Comment on
attachment 206909
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=206909&action=review
>> Source/WebCore/html/HTMLInputElement.h:305 >> + virtual void documentWillSuspendForPageCache() OVERRIDE; > > This ought to be wrapped in an ENABLE.
Sam gave me some comments in person and one of them was to keep the platform-specific statements out of WebCore (or at least out of ColorInputType.cpp). Thoughts?
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:142 >> + if (_lastChangedByUser) { > > What is the reason for this check? Can this be called by something else other than the color panel when the user chooses a color?
WKColorPanelMac::setColor, which is how <input type='color'>'s value is set programmatically.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:148 >> + _lastChangedByUser = NO; > > This is redundant.
Got it.
Ruth Fong
Comment 55
2013-07-19 14:11:07 PDT
Created
attachment 207142
[details]
Patch fixed style; removed most mac-specific preprocessing
Jon Lee
Comment 56
2013-07-19 14:17:03 PDT
Comment on
attachment 207142
[details]
Patch LGTM. Unofficial r=me.
Brady Eidson
Comment 57
2013-07-19 15:07:47 PDT
Comment on
attachment 207142
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207142&action=review
This review is ChangeLog Nazi-ism only, will continue reviewing code later...
> Source/JavaScriptCore/ChangeLog:5 > +
https://bugs.webkit.org/show_bug.cgi?id=61276
> + <
rdar://problem/10269922
>
These can be on the same line (and repeat for each ChangeLog)
> Source/WebCore/ChangeLog:10 > + Tests to be added in a later patch. > + No new tests (OOPS!).
Can't leave "OOPS!" in the log, the patch will be rejected. Just delete line 10.
> Source/WebCore/ChangeLog:24 > + * html/ColorInputType.cpp: > + (WebCore::ColorInputType::handleDOMActivateEvent): Updated to reattach > + the color picker if a color picker has already been shown for an element. > + > + (WebCore::ColorInputType::shouldResetOnDocumentActivation): Added. > + Returns true; needed to detach color chooser when caching a page.
I've never seen the style of paragraphing different functions within the same file, and I'm not a fan of it. I'd remove the empty line #22
> Source/WebCore/ChangeLog:27 > + * html/ColorInputType.h: > + * html/HTMLInputElement.cpp:
These two lines, however, should be paragraphed!
> Source/WebCore/ChangeLog:32 > + (WebCore::HTMLInputElement::documentDidResumeFromPageCache): Updated. > + For <input type='color'>, don't reset the element. > + > + (WebCore::HTMLInputElement::documentWillSuspendForPageCache): Added. > + For <input type='color'>, call detach().
Same here - line #30 grumble!
> Source/WebCore/ChangeLog:35 > + * html/HTMLInputElement.h: > + * platform/ColorChooser.h:
And same here, these two should be separated!
> Source/WebKit2/ChangeLog:8 > + Implemented <input type='color'> on Mac using the > + native color picker.
No reason to split this up in multiple lines.
> Source/WebKit2/ChangeLog:40 > + (WebKit::WebPageProxy::showColorChooser): Added mac-specific handling > + that allows showColorChooser to be called when first clicking on an > + <input type='color'> element. (Previously, showColorChooser assumed > + that m_colorChooser, which is owned by the web page, is null; > + disallowing multiple <input type='color'> elements on the same web page.) > + > + (WebKit::WebPageProxy::reattachColorChooser): Added. > + Reattached an <input type='color'> element (represented by m_colorChooser) > + to the color picker. > + > + (WebKit::WebPageProxy::didEndColorChooser): Added preprocessing for > + non-Mac platforms that have more color UI objects to clean up.
You can guess my comment here.
> Source/WebKit2/ChangeLog:56 > + (WebKit::WebColorChooserProxyMac::reattachColorChooser): > + WebColorChooserProxyMac contains a reference to a WKColorPanelMac object > + and is responsible for communicating between the WebProcess and > + the color picker UI.
In some descriptions you start on the same line as the method name then wrap. In others the entire description is newlined. I can't tell why the difference.
Ruth Fong
Comment 58
2013-07-19 15:31:02 PDT
Comment on
attachment 207142
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207142&action=review
>> Source/WebKit2/ChangeLog:56 >> + the color picker UI. > > In some descriptions you start on the same line as the method name then wrap. In others the entire description is newlined. I can't tell why the difference.
In this case because this describes the above functions, not just the reattachColorChooser function.
Ruth Fong
Comment 59
2013-07-19 15:48:24 PDT
Created
attachment 207155
[details]
Patch fixed style in changelogs
Brady Eidson
Comment 60
2013-07-19 16:04:02 PDT
Comment on
attachment 207155
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207155&action=review
> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:86 > void WebColorChooser::setSelectedColor(const Color& color) > { > if (!m_page) > return; > + > + if (m_page->activeColorChooser() != this) > + return;
In what case would this happen?
> LayoutTests/media/track/track-disabled-expected.txt:-6 > -EVENT(loadstart) > -Waiting for the duration of the first cue to elapse. > -The duration of the first cue has elapsed. > - > -END OF TEST > -
What?
> LayoutTests/media/track/track-disabled.html:-39 > -<!DOCTYPE html> > -<html> > - <head> > - <script src="../media-file.js"></script> > - <script src="../video-test.js"></script> > - <script> > - waitForEvent('loadstart', function () > - { > - var video = document.getElementById('vid'); > - video.textTracks[0].mode = "disabled"; > - > - consoleWrite("Waiting for the duration of the first cue to elapse."); > - video.addEventListener('timeupdate', function (e) > - { > - if (e.target.currentTime < 1) > - return; > - > - // End test after the duration of the first cue to make sure the test > - // doesn't crash during the period this cue would have been > - // rendered if the track was not disabled. > - consoleWrite("The duration of the first cue has elapsed.<br>"); > - endTest(); > - }); > - }); > - > - function start() > - { > - findMediaElement(); > - video.src = findMediaFile('video', '../content/test'); > - } > - > - </script> > - </head> > - <body onload="start()"> > - <video id="vid" autoplay controls> > - <track kind='subtitles' srclang='en' label='English' src='captions-webvtt/captions.vtt' /> > - </video> > - </body> > -</html>
What?
Ruth Fong
Comment 61
2013-07-19 16:17:06 PDT
Comment on
attachment 207155
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207155&action=review
>> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:86 >> + return; > > In what case would this happen?
When you have two <input type='color'> elements (i.e. <input type='color' id='c1'> and <input type='color' id='c2'>). If the second element is currently associated to the color picker and is the active color chooser, and the first element is being programatically set (i.e. c1.value = '#000000';). It's not the active color chooser, so it shouldn't change the color in the color picker.
>> LayoutTests/media/track/track-disabled-expected.txt:-6 >> - > > What?
Hmm, I think this is from another bug I was working on. I must've accidentally deleted it. Sorry; ignore this.
>> LayoutTests/media/track/track-disabled.html:-39 >> -</html> > > What?
Same.
Ruth Fong
Comment 62
2013-07-22 11:39:35 PDT
Created
attachment 207257
[details]
Patch
Brady Eidson
Comment 63
2013-07-23 14:54:38 PDT
Comment on
attachment 207257
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207257&action=review
> Source/WebCore/ChangeLog:21 > + * html/ColorInputType.cpp: > + (WebCore::ColorInputType::handleDOMActivateEvent): Updated to reattach the color picker if a > + color picker has already been shown for an element. > + (WebCore::ColorInputType::shouldResetOnDocumentActivation): Always returns true, needed to > + detach color chooser when caching a page. > + > + * html/ColorInputType.h:
line #20 is unnecessary - ColorInputType.h is logically connected to the .cpp
> Source/WebCore/ChangeLog:28 > + * html/HTMLInputElement.cpp: > + (WebCore::HTMLInputElement::documentDidResumeFromPageCache): For <input type='color'>, > + don't reset the element. > + (WebCore::HTMLInputElement::documentWillSuspendForPageCache): For <input type='color'>, call detach(). > + > + * html/HTMLInputElement.h:
Same here... and same for all Changelogs
> Source/WebCore/html/HTMLInputElement.cpp:1978 > + if (!isColorControl()) > + return; > + static_cast<InputType*>(m_inputType.get())->detach();
This should be a cast to ColorInputType*
> Source/WebKit2/ChangeLog:40 > + * UIProcess/WebPageProxy.cpp: > + (WebKit::WebPageProxy::showColorChooser): Added mac-specific handling > + that allows showColorChooser to be called when first clicking on an > + <input type='color'> element. (Previously, showColorChooser assumed > + that m_colorChooser, which is owned by the web page, is null; > + disallowing multiple <input type='color'> elements on the same web page.) > + (WebKit::WebPageProxy::reattachColorChooser): Added. Reattaches an > + <input type='color'> element (represented by m_colorChooser) > + to the color picker. > + (WebKit::WebPageProxy::didEndColorChooser): Added preprocessing for > + non-Mac platforms that have more color UI objects to clean up. > + > + * UIProcess/WebPageProxy.h: > + > + * UIProcess/WebPageProxy.messages.in: Updated to include the definition of ReattachColorChooser.
And in WK2, we often even leave the .cpp, .h, and .messages.in all paragraphed together (no empty line between them)
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2933 > +#if PLATFORM(MAC) > + if (!m_colorChooser) > + m_colorChooser = m_pageClient->createColorChooserProxy(this, initialColor, elementRect); > + else { > + // Handles the case where a color picker already exists for the web process. > + reattachColorChooser(initialColor); > + } > +#else
In general, I'm confused as to why this method has a completely different code path for Mac than the code path that already exists in this method. I don't seen any particular reason why the #if PLATFORM(MAC) code is inherently incompatible with how you want Mac to behave. Also, this file is not the correct place for a PLATFORM(MAC) ifdef.
> Source/WebKit2/UIProcess/WebPageProxy.cpp:2999 > +#if !PLATFORM(MAC) > m_colorPickerResultListener->invalidate(); > m_colorPickerResultListener = nullptr; > > m_uiClient.hideColorPicker(this); > +#endif // PLATFORM(MAC)
Also, this file is not the correct place for a !PLATFORM(MAC) ifdef
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:38 > + > +#if USE(APPKIT) > +
Wut?
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:49 > +namespace WebCore { > + > +class Color; > + > +}
l46 and l48 are unnecessary
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:38 > + > +#if USE(APPKIT) > +
Wut.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:87 > + // Handle the case where the color picker has been closed for an <input type='color'> element.
Not sure this comment is useful.
> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.mm:100 > +- (id)initWithChooser:(WebKit::WebColorChooserProxyMac*)chooser withColor:(NSColor *)color
Instead of the WebKit::, please do a `using namespace WebKit` above the @implmentation.
> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:669 > PassOwnPtr<ColorChooser> WebChromeClient::createColorChooser(ColorChooserClient* client, const Color& initialColor) > { > +#if !PLATFORM(MAC) > if (m_page->activeColorChooser()) > return nullptr; > - > +#endif > return adoptPtr(new WebColorChooser(m_page, client, initialColor)); > }
It seems super peculiar to me that previously this method *always* returned a ColorChooser, and yet your code sometimes does not. That can't be right, can it? Why do other implementations always want a fresh chooser, but this implementation returns null if one already exists? Also, this file is not the correct place for a PLATFORM(MAC) ifdef.
> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:86 > void WebColorChooser::setSelectedColor(const Color& color) > { > if (!m_page) > return; > + > + if (m_page->activeColorChooser() != this) > + return;
It seems wrong that the inactive chooser doesn't get its color set as requested. If a different color chooser is now the active one, shouldn't this one's color still be updated?
> Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:730 > +PassOwnPtr<ColorChooser> WebChromeClient::createColorChooser(ColorChooserClient* client, const Color& initialColor) > +{ > + notImplemented(); > + return nullptr; > +}
This seems wrong,
Ruth Fong
Comment 64
2013-07-24 09:45:35 PDT
Comment on
attachment 207257
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207257&action=review
>> Source/WebCore/html/HTMLInputElement.cpp:1978 >> + static_cast<InputType*>(m_inputType.get())->detach(); > > This should be a cast to ColorInputType*
ColorInputType::detach() is private. I think the original intention was that detach() would never be directly called.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2933 >> +#else > > In general, I'm confused as to why this method has a completely different code path for Mac than the code path that already exists in this method. > > I don't seen any particular reason why the #if PLATFORM(MAC) code is inherently incompatible with how you want Mac to behave. > > Also, this file is not the correct place for a PLATFORM(MAC) ifdef.
Got it.
Bug 119030
will track refactoring this platform specific code.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2999 >> +#endif // PLATFORM(MAC) > > Also, this file is not the correct place for a !PLATFORM(MAC) ifdef
See
bug 119030
.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:38 >> + > > Wut?
AppKit is used for NSColorPanel.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:669 >> } > > It seems super peculiar to me that previously this method *always* returned a ColorChooser, and yet your code sometimes does not. > That can't be right, can it? > > Why do other implementations always want a fresh chooser, but this implementation returns null if one already exists? > > Also, this file is not the correct place for a PLATFORM(MAC) ifdef.
I think the previous implementation only allowed one WebColorChooser per WebPage. Will remove this though.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:86 >> + return; > > It seems wrong that the inactive chooser doesn't get its color set as requested. > > If a different color chooser is now the active one, shouldn't this one's color still be updated?
This is for setting the color in the color picker UI. If JavaScript changes the color of an <input type='color'> that's not the active color element, it will only change the swatch of the color element, not the selected color in the color picker, which is associated to another color element.
>> Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:730 >> +} > > This seems wrong,
This patch tracks implementing <input type='color'> for Mac on WK2; this is WK1. Will change to ASSERT_NOT_REACHED().
Ruth Fong
Comment 65
2013-07-24 09:45:42 PDT
Comment on
attachment 207257
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207257&action=review
>> Source/WebCore/html/HTMLInputElement.cpp:1978 >> + static_cast<InputType*>(m_inputType.get())->detach(); > > This should be a cast to ColorInputType*
ColorInputType::detach() is private. I think the original intention was that detach() would never be directly called.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2933 >> +#else > > In general, I'm confused as to why this method has a completely different code path for Mac than the code path that already exists in this method. > > I don't seen any particular reason why the #if PLATFORM(MAC) code is inherently incompatible with how you want Mac to behave. > > Also, this file is not the correct place for a PLATFORM(MAC) ifdef.
Got it.
Bug 119030
will track refactoring this platform specific code.
>> Source/WebKit2/UIProcess/WebPageProxy.cpp:2999 >> +#endif // PLATFORM(MAC) > > Also, this file is not the correct place for a !PLATFORM(MAC) ifdef
See
bug 119030
.
>> Source/WebKit2/UIProcess/mac/WebColorChooserProxyMac.h:38 >> + > > Wut?
AppKit is used for NSColorPanel.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebChromeClient.cpp:669 >> } > > It seems super peculiar to me that previously this method *always* returned a ColorChooser, and yet your code sometimes does not. > That can't be right, can it? > > Why do other implementations always want a fresh chooser, but this implementation returns null if one already exists? > > Also, this file is not the correct place for a PLATFORM(MAC) ifdef.
I think the previous implementation only allowed one WebColorChooser per WebPage. Will remove this though.
>> Source/WebKit2/WebProcess/WebCoreSupport/WebColorChooser.cpp:86 >> + return; > > It seems wrong that the inactive chooser doesn't get its color set as requested. > > If a different color chooser is now the active one, shouldn't this one's color still be updated?
This is for setting the color in the color picker UI. If JavaScript changes the color of an <input type='color'> that's not the active color element, it will only change the swatch of the color element, not the selected color in the color picker, which is associated to another color element.
>> Source/WebKit/mac/WebCoreSupport/WebChromeClient.mm:730 >> +} > > This seems wrong,
This patch tracks implementing <input type='color'> for Mac on WK2; this is WK1. Will change to ASSERT_NOT_REACHED().
Ruth Fong
Comment 66
2013-07-25 11:42:28 PDT
Created
attachment 207471
[details]
Patch
Tim Horton
Comment 67
2013-07-25 14:30:12 PDT
Comment on
attachment 207471
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207471&action=review
> Source/WebCore/WebCore.xcodeproj/project.pbxproj:-4411 > - 85174EC2BCCAF17EAE3F46F8 /* JSSVGGraphicsElement.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 5A91469E8E9F8485C37A2876 /* JSSVGGraphicsElement.cpp */; }; > - 7BE7427381FA906FBB4F0F2C /* JSSVGGraphicsElement.h in Headers */ = {isa = PBXBuildFile; fileRef = 950C4C02BED8936F818E2F99 /* JSSVGGraphicsElement.h */; };
Xcode is still touching stuff it shouldn't. Can we land these in a different patch to appease it (have you reverted these and it's gone ahead and done it again?) and reduce the size of your already large patch.
> Source/WebCore/html/HTMLInputElement.cpp:1978 > + static_cast<InputType*>(m_inputType.get())->detach();
Why are you casting an InputType* to an InputType*?
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:70 > + if (!m_client) > + return; > + > + if (!m_panel) > + return;
could merge these
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:107 > + [panel setShowsAlpha:NO];
Is there a bug about supporting alpha in the future? How does the spec handle that?
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:147 > + // Check if the color changed programatically or through the color picker.
Typo programmatically. And this comment is a little weird (it's a bit "what" and not enough "why").
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:153 > + _picker->didChooseColor(WebCore::colorFromNSColor([[panel color] colorUsingColorSpaceName:NSDeviceRGBColorSpace]));
colorFromNSColor already shoves the NSColor into DeviceRGB, so you don't need to. Also I'd really like to avoid adding more places where we explicitly name DeviceRGB for ... reasons. So please remove that part.
Ruth Fong
Comment 68
2013-07-25 15:39:58 PDT
Comment on
attachment 207471
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207471&action=review
>> Source/WebCore/WebCore.xcodeproj/project.pbxproj:-4411 >> - 7BE7427381FA906FBB4F0F2C /* JSSVGGraphicsElement.h in Headers */ = {isa = PBXBuildFile; fileRef = 950C4C02BED8936F818E2F99 /* JSSVGGraphicsElement.h */; }; > > Xcode is still touching stuff it shouldn't. Can we land these in a different patch to appease it (have you reverted these and it's gone ahead and done it again?) and reduce the size of your already large patch.
Yes; even after reverting and updating, it's doing this. I'll land a different patch to simply add ColorInputType.cpp to the project (
bug 119111
).
>> Source/WebCore/html/HTMLInputElement.cpp:1978 >> + static_cast<InputType*>(m_inputType.get())->detach(); > > Why are you casting an InputType* to an InputType*?
Good catch. Initially I was casting to ColorInputType, but it's detach method is private since it was never meant to be called directly. Will remove casting in next patch.
>> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:70 >> + return; > > could merge these
Yup.
>> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:107 >> + [panel setShowsAlpha:NO]; > > Is there a bug about supporting alpha in the future? How does the spec handle that?
No, the HTML5 spec does not support alpha.
>> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:147 >> + // Check if the color changed programatically or through the color picker. > > Typo programmatically. And this comment is a little weird (it's a bit "what" and not enough "why").
Got it. This block is executed if setColor is called programatically, which occurs when JavaScript is used to change the value of an <input type='color'> element. If the user changes the color uses the native mac color picker, then this block is skipped. It may make more sense to move the comment down to line 152 and say something like "When user picks a color in the color picker, transmit that selection down to the element to change its value".
>> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:153 >> + _picker->didChooseColor(WebCore::colorFromNSColor([[panel color] colorUsingColorSpaceName:NSDeviceRGBColorSpace])); > > colorFromNSColor already shoves the NSColor into DeviceRGB, so you don't need to. Also I'd really like to avoid adding more places where we explicitly name DeviceRGB for ... reasons. So please remove that part.
Got it.
Ruth Fong
Comment 69
2013-07-25 17:07:38 PDT
Created
attachment 207495
[details]
Patch
Build Bot
Comment 70
2013-07-29 20:31:56 PDT
Comment on
attachment 207495
[details]
Patch
Attachment 207495
[details]
did not pass win-ews (win): Output:
http://webkit-queues.appspot.com/results/1287211
Brady Eidson
Comment 71
2013-07-30 15:41:08 PDT
Comment on
attachment 207495
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207495&action=review
> Source/WebCore/html/HTMLInputElement.cpp:1978 > + m_inputType.get()->detach();
No need for .get() (from Brady)
Sam Weinig
Comment 72
2013-07-30 16:15:57 PDT
Comment on
attachment 207495
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207495&action=review
> Source/WebCore/html/HTMLInputElement.cpp:1980 > +#if ENABLE(INPUT_TYPE_COLOR) > +void HTMLInputElement::documentWillSuspendForPageCache() > +{ > + if (!isColorControl()) > + return; > + m_inputType.get()->detach(); > +} > +#endif // ENABLE(INPUT_TYPE_COLOR)
This should go next to documentDidResumeFromPageCache.
> Source/WebCore/html/HTMLInputElement.h:307 > +#if ENABLE(INPUT_TYPE_COLOR) > + virtual void documentWillSuspendForPageCache() OVERRIDE; > +#endif
This should go next to documentDidResumeFromPageCache().
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.h:70 > +// A Listener class to act as a event target for NSColorPanel and send
Unnecessary capital L.
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.h:74 > +@interface WKColorPanelMac : NSObject<NSWindowDelegate> { > + > +@private
Unnecessary newline.
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:134 > +- (void)dealloc > +{ > + NSColorPanel *panel = [NSColorPanel sharedColorPanel]; > + if ([panel delegate] == self) { > + [panel setDelegate:nil]; > + [panel setTarget:nil]; > + [panel setAction:nil]; > + } > + > + [super dealloc]; > +}
You should move this to an invalidate method.
Ruth Fong
Comment 73
2013-07-30 22:41:02 PDT
Created
attachment 207808
[details]
Patch
Ruth Fong
Comment 74
2013-07-30 22:44:38 PDT
Comment on
attachment 207808
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207808&action=review
> Source/WebKit2/UIProcess/mac/WebColorPickerMac.mm:123 > +- (void)setAndShowPicker:(WebColorPickerMac*)picker withColor:(NSColor *)color
Moved setup logic here because some various set-up work needs to be done when moving between color elements on the same page and across different tabs (i.e. panel object may be non-null when another color element is clicked but certain set-up like setting the delegate and target needs to be done).
Build Bot
Comment 75
2013-07-30 23:28:07 PDT
Comment on
attachment 207808
[details]
Patch
Attachment 207808
[details]
did not pass win-ews (win): Output:
http://webkit-queues.appspot.com/results/1292568
Brady Eidson
Comment 76
2013-07-31 10:19:23 PDT
Comment on
attachment 207808
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=207808&action=review
I think I know why this broke the Windows build. Everything else looks fine. r- for now, but please upload a new patch to fix the windows build and i'll r+ that.
> Source/WTF/wtf/FeatureDefines.h:507 > #if !defined(ENABLE_INPUT_TYPE_COLOR) > -#define ENABLE_INPUT_TYPE_COLOR 0 > +#define ENABLE_INPUT_TYPE_COLOR 1 > #endif
I think the reason the windows build broke was because this clause globally enables the feature on all platforms that haven't decided to enable/disable it earlier in FeatureDefines.h You should probably leave this clause alone, and add a new "#define ENABLE_INPUT_TYPE_COLOR 1" clause to the "/* --------- Apple MAC port (not IOS) --------- */" section of the file.
Ruth Fong
Comment 77
2013-07-31 10:24:20 PDT
Created
attachment 207858
[details]
Patch
Brady Eidson
Comment 78
2013-07-31 11:14:36 PDT
Comment on
attachment 207858
[details]
Patch r+ after looking at FeatureDefines.h and blindly assuming Ruth didn't make other changes from the previous patch. :)
WebKit Commit Bot
Comment 79
2013-07-31 13:46:31 PDT
Comment on
attachment 207858
[details]
Patch Clearing flags on attachment: 207858 Committed
r153541
: <
http://trac.webkit.org/changeset/153541
>
WebKit Commit Bot
Comment 80
2013-07-31 13:46:41 PDT
All reviewed patches have been landed. Closing bug.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug