summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorpinkerton@chromium.org <pinkerton@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-09 17:39:34 +0000
committerpinkerton@chromium.org <pinkerton@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-06-09 17:39:34 +0000
commit9a556e3307dacc7e6d84517d3b78b86c6dbd84f1 (patch)
tree2468136819412b6be807049fbf6a3d5a02e4ab1c /chrome
parent2216683346b44b088820c64c5757bb66365acda3 (diff)
downloadchromium_src-9a556e3307dacc7e6d84517d3b78b86c6dbd84f1.zip
chromium_src-9a556e3307dacc7e6d84517d3b78b86c6dbd84f1.tar.gz
chromium_src-9a556e3307dacc7e6d84517d3b78b86c6dbd84f1.tar.bz2
Add a stack-based class for property disabling and re-enabling screen updating without epic fail. Fixes issues where we weren't re-enabling updates in many cases which caused both jank and resize issues.
BUG=13476 TEST=closing windows shouldn't have jank regardless of the # of tabs. Resizing a window shouldn't explode visually in the chrome. Review URL: http://codereview.chromium.org/119363 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@17956 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rw-r--r--chrome/browser/cocoa/browser_window_controller.mm7
1 files changed, 3 insertions, 4 deletions
diff --git a/chrome/browser/cocoa/browser_window_controller.mm b/chrome/browser/cocoa/browser_window_controller.mm
index 9fa2ee0..f8342d0 100644
--- a/chrome/browser/cocoa/browser_window_controller.mm
+++ b/chrome/browser/cocoa/browser_window_controller.mm
@@ -3,6 +3,7 @@
// found in the LICENSE file.
#include "base/mac_util.h"
+#include "base/scoped_nsdisable_screen_updates.h"
#include "base/sys_string_conversions.h"
#include "chrome/app/chrome_dll_resource.h" // IDC_*
#include "chrome/browser/browser.h"
@@ -193,7 +194,7 @@ willPositionSheet:(NSWindow *)sheet
// going away) will again call to close the window when it's finally ready.
- (BOOL)windowShouldClose:(id)sender {
// Disable updates while closing all tabs to avoid flickering.
- NSDisableScreenUpdates();
+ base::ScopedNSDisableScreenUpdates disabler;
// Give beforeunload handlers the chance to cancel the close before we hide
// the window below.
if (!browser_->ShouldCloseWindow())
@@ -212,7 +213,6 @@ willPositionSheet:(NSWindow *)sheet
browser_->OnWindowClosing();
return NO;
}
- NSEnableScreenUpdates();
// the tab strip is empty, it's ok to close the window
return YES;
@@ -462,7 +462,7 @@ willPositionSheet:(NSWindow *)sheet
- (TabWindowController*)detachTabToNewWindow:(TabView*)tabView {
// Disable screen updates so that this appears as a single visual change.
- NSDisableScreenUpdates();
+ base::ScopedNSDisableScreenUpdates disabler;
// Fetch the tab contents for the tab being dragged
int index = [tabStripController_ indexForTabView:tabView];
@@ -507,7 +507,6 @@ willPositionSheet:(NSWindow *)sheet
// And make sure we use the correct frame in the new view.
[[controller tabStripController] setFrameOfSelectedTab:tabRect];
- NSEnableScreenUpdates();
return controller;
}