Change macos app termination process

This commit is contained in:
Nitish Sakhawalkar 2018-01-11 14:50:35 -08:00 committed by Cheng Zhao
parent d69c17a96a
commit 28f1abcb05
4 changed files with 31 additions and 9 deletions

View file

@ -4,6 +4,7 @@
#import "atom/browser/mac/atom_application.h" #import "atom/browser/mac/atom_application.h"
#import "atom/browser/mac/atom_application_delegate.h"
#include "atom/browser/mac/dict_util.h" #include "atom/browser/mac/dict_util.h"
#include "atom/browser/browser.h" #include "atom/browser/browser.h"
#include "base/auto_reset.h" #include "base/auto_reset.h"
@ -27,6 +28,11 @@ inline void dispatch_sync_main(dispatch_block_t block) {
return (AtomApplication*)[super sharedApplication]; return (AtomApplication*)[super sharedApplication];
} }
- (void)terminate:(id)sender {
AtomApplicationDelegate* atomDelegate = (AtomApplicationDelegate*) [NSApp delegate];
[atomDelegate tryToTerminateApp:self];
}
- (BOOL)isHandlingSendEvent { - (BOOL)isHandlingSendEvent {
return handlingSendEvent_; return handlingSendEvent_;
} }

View file

@ -11,6 +11,8 @@
base::scoped_nsobject<AtomMenuController> menu_controller_; base::scoped_nsobject<AtomMenuController> menu_controller_;
} }
- (void)tryToTerminateApp:(NSApplication*)app;
// Sets the menu that will be returned in "applicationDockMenu:". // Sets the menu that will be returned in "applicationDockMenu:".
- (void)setApplicationDockMenu:(atom::AtomMenuModel*)model; - (void)setApplicationDockMenu:(atom::AtomMenuModel*)model;

View file

@ -87,15 +87,11 @@ static base::mac::ScopedObjCClassSwizzler* g_swizzle_imk_input_session;
return atom::Browser::Get()->OpenFile(filename_str) ? YES : NO; return atom::Browser::Get()->OpenFile(filename_str) ? YES : NO;
} }
- (NSApplicationTerminateReply)applicationShouldTerminate:(NSApplication*)sender { // We simply try to close the browser, which in turn will try to close the windows.
atom::Browser* browser = atom::Browser::Get(); // Termination can proceed if all windows are closed or window close can be cancelled
if (browser->is_quiting()) { // which will abort termination.
return NSTerminateNow; - (void)tryToTerminateApp:(NSApplication*)app {
} else {
// System started termination.
atom::Browser::Get()->Quit(); atom::Browser::Get()->Quit();
return NSTerminateCancel;
}
} }
- (BOOL)applicationShouldHandleReopen:(NSApplication*)theApplication - (BOOL)applicationShouldHandleReopen:(NSApplication*)theApplication

View file

@ -157,6 +157,24 @@ describe('app module', () => {
done() done()
}) })
}) })
it('exits gracefully on macos', (done) => {
if (process.platform !== 'darwin') {
this.skip()
}
const appPath = path.join(__dirname, 'fixtures', 'api', 'singleton')
const electronPath = remote.getGlobal('process').execPath
appProcess = ChildProcess.spawn(electronPath, [appPath])
appProcess.stdout.once('data', () => {
// The apple script will try to terminate the app
// If there's an error terminating the app, then it will print to stderr
ChildProcess.exec('osascript -e \'quit app "Electron"\'', (err, stdout, stderr) => {
assert(!err)
assert(!stderr.trim())
done()
})
})
})
}) })
describe('app.makeSingleInstance', () => { describe('app.makeSingleInstance', () => {