summaryrefslogtreecommitdiffstats
path: root/chrome/browser/app_controller_mac.mm
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/app_controller_mac.mm')
-rw-r--r--chrome/browser/app_controller_mac.mm11
1 files changed, 10 insertions, 1 deletions
diff --git a/chrome/browser/app_controller_mac.mm b/chrome/browser/app_controller_mac.mm
index cf0c49f..16073d8 100644
--- a/chrome/browser/app_controller_mac.mm
+++ b/chrome/browser/app_controller_mac.mm
@@ -5,13 +5,14 @@
#import "app_controller_mac.h"
#import "base/message_loop.h"
+#import "chrome/browser/browser_list.h"
@implementation AppController
// We can't use the standard terminate: method because it will abrubptly exit
// the app and leave things on the stack in an unfinalized state. We need to
// post a quit message to our run loop so the stack can gracefully unwind.
-- (IBAction)quit:(id)sender {
+- (IBAction)quit:(id)sender {
// TODO(pinkerton):
// since we have to roll it ourselves, ask the delegate (ourselves, really)
// if we should terminate. For example, we might not want to if the user
@@ -19,6 +20,14 @@
// require posting UI and may require spinning up another run loop to
// handle it. If it says to continue, post the quit message, otherwise
// go back to normal.
+
+ // Close all the windows.
+ // TODO(pinkerton): the close code assumes that teardown happens
+ // synchronously, however with autorelease pools and ref-counting, we can't
+ // guarantee the window controller hits 0 inside this call, and thus the
+ // number of Browsers still alive will certainly be non-zero. Not sure yet
+ // how to handle this case.
+ // BrowserList::CloseAllBrowsers(false);
MessageLoopForUI::current()->Quit();
}