RESOLVED FIXED 126214
Merge PageVisibilityState & ViewState::IsVisible in WebKit2
https://bugs.webkit.org/show_bug.cgi?id=126214
Summary Merge PageVisibilityState & ViewState::IsVisible in WebKit2
Gavin Barraclough
Reported 2013-12-24 08:34:52 PST
WebKit2 redundantly tracks the visibility of the view through two mechanisms - the visibility state, and the view state. Remove visibility state from the WebKit2 layer. The visibility state also tracks the 'pretender' state - so split this out and handle it separately (a change we should make in WebCore, too). Removing the redundancy also removes the ability from the API to set a fake visibility state (IsVisible tracks the actual visibility of the view). Through private API (WKPageSetVisibilityState) a client could previously request the view be reported as hidden/visible, but this didn't really work - the override was not enforced and the API may reset the state at an arbitrary point. The mechanism is only used by testing code, which instead should actually update the view visibility (this tests more of the actual visibility mechanisms used by the browser). The one aspect of the API relied on by existing clients is the ability to initialize a hidden view as prerender -continue to support this specific functionality via WKPageSetVisibilityState, to maintain backwards compatibility.
Attachments
Fixed? (41.48 KB, patch)
2013-12-25 14:13 PST, Gavin Barraclough
eflews.bot: commit-queue-
style, efl fixes (42.22 KB, patch)
2013-12-25 14:30 PST, Gavin Barraclough
eflews.bot: commit-queue-
efl build fix take 2 (42.71 KB, patch)
2013-12-25 15:43 PST, Gavin Barraclough
no flags
Stupid autocorrect :-( ... s/pretender/prerender/ in Changelog (42.71 KB, patch)
2013-12-25 21:57 PST, Gavin Barraclough
ap: review+
Gavin Barraclough
Comment 1 2013-12-25 14:13:22 PST
WebKit Commit Bot
Comment 2 2013-12-25 14:15:09 PST
Attachment 220000 [details] did not pass style-queue: Failed to run "['Tools/Scripts/check-webkit-style', '--diff-files', u'LayoutTests/ChangeLog', u'LayoutTests/fast/events/page-visibility-transition-test-expected.txt', u'LayoutTests/fast/events/page-visibility-transition-test.html', u'Source/WebCore/ChangeLog', u'Source/WebCore/page/Page.cpp', u'Source/WebKit2/ChangeLog', u'Source/WebKit2/UIProcess/API/C/WKPage.cpp', u'Source/WebKit2/UIProcess/WebPageProxy.cpp', u'Source/WebKit2/UIProcess/WebPageProxy.h', u'Source/WebKit2/WebProcess/WebPage/WebPage.cpp', u'Source/WebKit2/WebProcess/WebPage/WebPage.h', u'Source/WebKit2/WebProcess/WebPage/WebPage.messages.in', u'Tools/ChangeLog', u'Tools/TestWebKitAPI/TestWebKitAPI.xcodeproj/project.pbxproj', u'Tools/TestWebKitAPI/Tests/WebKit2/PageVisibilityState.cpp', u'Tools/TestWebKitAPI/Tests/mac/PageVisibilityStateWithWindowChanges.mm', u'Tools/WebKitTestRunner/TestController.cpp', u'Tools/WebKitTestRunner/TestController.h', u'Tools/WebKitTestRunner/efl/TestControllerEfl.cpp', u'Tools/WebKitTestRunner/gtk/TestControllerGtk.cpp', u'Tools/WebKitTestRunner/mac/TestControllerMac.mm', '--commit-queue']" exit_code: 1 ERROR: Tools/WebKitTestRunner/TestController.h:167: The parameter name "hidden" adds no information, so it should be removed. [readability/parameter_name] [5] Total errors found: 1 in 18 files If any of these errors are false positives, please file a bug against check-webkit-style.
EFL EWS Bot
Comment 3 2013-12-25 14:21:41 PST
Gavin Barraclough
Comment 4 2013-12-25 14:30:26 PST
Created attachment 220002 [details] style, efl fixes
EFL EWS Bot
Comment 5 2013-12-25 14:45:59 PST
Comment on attachment 220002 [details] style, efl fixes Attachment 220002 [details] did not pass efl-wk2-ews (efl-wk2): Output: http://webkit-queues.appspot.com/results/6107173985714176
Gavin Barraclough
Comment 6 2013-12-25 15:43:19 PST
Created attachment 220008 [details] efl build fix take 2
Gavin Barraclough
Comment 7 2013-12-25 21:57:08 PST
Created attachment 220022 [details] Stupid autocorrect :-( ... s/pretender/prerender/ in Changelog
Alexey Proskuryakov
Comment 8 2013-12-27 00:48:22 PST
Comment on attachment 220022 [details] Stupid autocorrect :-( ... s/pretender/prerender/ in Changelog View in context: https://bugs.webkit.org/attachment.cgi?id=220022&action=review > Source/WebCore/ChangeLog:20 > + by the browser). The one aspect of the API relied on by existing clients is the ability to > + initialize a hidden view as prerender -continue to support this specific functionality via Seems like there should be a space in "-continue". > Source/WebCore/ChangeLog:23 > + > + Extra blank line. > Source/WebCore/ChangeLog:24 > + WebCore - chnages the the API tests exposed a bug, a view should only ever come out of the chnages, the the > Source/WebKit2/ChangeLog:20 > + initialize a hidden view as prerender -continue to support this specific functionality via -continue > Source/WebKit2/ChangeLog:23 > + > + Extra blank line. > Tools/ChangeLog:23 > + initialize a hidden view as prerender -continue to support this specific functionality via > + WKPageSetVisibilityState, to maintain backwards compatibility. > + > + ... Does this really need to be repeated in every ChangeLog? I usually put extra info into a project that had the most changes - they are all combined for commit message anyway. > Tools/WebKitTestRunner/mac/TestControllerMac.mm:90 > + [window makeKeyAndOrderFront:nil]; Hopefully it's not forced back on screen, so nothing visually blinks and prevents using the computer while tests are running? > Tools/WebKitTestRunner/mac/TestControllerMac.mm:91 > + [NSApp activateIgnoringOtherApps:YES]; Why is this needed? A comment would probably be of use.
Gavin Barraclough
Comment 9 2013-12-27 11:40:46 PST
(In reply to comment #8) > > Tools/WebKitTestRunner/mac/TestControllerMac.mm:90 > > + [window makeKeyAndOrderFront:nil]; > > Hopefully it's not forced back on screen, so nothing visually blinks and prevents using the computer while tests are running? No,from my testing the window is not actually forced onscreen. > > Tools/WebKitTestRunner/mac/TestControllerMac.mm:91 > > + [NSApp activateIgnoringOtherApps:YES]; > > Why is this needed? A comment would probably be of use. You're right, looks like this was overkill - removed. Thanks Alexey!
Gavin Barraclough
Comment 10 2013-12-27 11:42:34 PST
Committed revision 161105.
Note You need to log in before you can comment on or make changes to this bug.