Index: chrome/browser/ui/cocoa/browser_window_controller.mm |
diff --git a/chrome/browser/ui/cocoa/browser_window_controller.mm b/chrome/browser/ui/cocoa/browser_window_controller.mm |
index 73eba37f94c7ee1ae02ad9bdb24648e68dbd8b82..c490bf119de2272a7715108527c40ce7991df9d3 100644 |
--- a/chrome/browser/ui/cocoa/browser_window_controller.mm |
+++ b/chrome/browser/ui/cocoa/browser_window_controller.mm |
@@ -596,12 +596,24 @@ enum { |
// have to save the window position before we call orderOut:. |
[self saveWindowPositionIfNeeded]; |
+ bool fast_tab_closing_enabled = |
+ CommandLine::ForCurrentProcess()->HasSwitch(switches::kEnableFastUnload); |
+ |
if (!browser_->tab_strip_model()->empty()) { |
// Tab strip isn't empty. Hide the frame (so it appears to have closed |
// immediately) and close all the tabs, allowing the renderers to shut |
// down. When the tab strip is empty we'll be called back again. |
[[self window] orderOut:self]; |
browser_->OnWindowClosing(); |
+ if (fast_tab_closing_enabled) |
+ browser_->tab_strip_model()->CloseAllTabs(); |
+ return NO; |
+ } else if (fast_tab_closing_enabled && |
+ !browser_->HasCompletedUnloadProcessing()) { |
+ // The browser needs to finish running unload handlers. |
+ // Hide the window (so it appears to have closed immediately), and |
+ // the browser will call us back again when it is ready to close. |
+ [[self window] orderOut:self]; |
return NO; |
} |