diff options
author | Abhi Beckert <abhi@abhibeckert.com> | 2015-05-16 08:45:26 +1000 |
---|---|---|
committer | Abhi Beckert <abhi@abhibeckert.com> | 2015-05-16 08:45:26 +1000 |
commit | 57d0d4400d25265dee4e70376e8c9ab6b96e8f79 (patch) | |
tree | 921a781c919cfd3cfb3cf27e7509577e588e52cc /Source/SPAppController.m | |
parent | 0f0c43eb74408b6a65a42e2c6fd46f4142ef8e3f (diff) | |
parent | 7654a9f82f621cc668414fc0b632a92382f7e51c (diff) | |
download | sequelpro-57d0d4400d25265dee4e70376e8c9ab6b96e8f79.tar.gz sequelpro-57d0d4400d25265dee4e70376e8c9ab6b96e8f79.tar.bz2 sequelpro-57d0d4400d25265dee4e70376e8c9ab6b96e8f79.zip |
Merge pull request #2116 from abhibeckert/master
Changes by Andreas Beier from MAMP
Diffstat (limited to 'Source/SPAppController.m')
-rw-r--r-- | Source/SPAppController.m | 52 |
1 files changed, 51 insertions, 1 deletions
diff --git a/Source/SPAppController.m b/Source/SPAppController.m index 0d60437b..9b658dc4 100644 --- a/Source/SPAppController.m +++ b/Source/SPAppController.m @@ -139,6 +139,21 @@ */ - (void)applicationDidFinishLaunching:(NSNotification *)notification { + NSDictionary *spfDict = nil; + NSArray *args = [[NSProcessInfo processInfo] arguments]; + if (args.count == 5) { + if (([[args objectAtIndex:1] isEqualToString:@"--spfData"] && [[args objectAtIndex:3] isEqualToString:@"--dataVersion"] && [[args objectAtIndex:4] isEqualToString:@"1"]) || ([[args objectAtIndex:3] isEqualToString:@"--spfData"] && [[args objectAtIndex:1] isEqualToString:@"--dataVersion"] && [[args objectAtIndex:2] isEqualToString:@"1"])) { + NSData* data = [[args objectAtIndex:2] dataUsingEncoding:NSUTF8StringEncoding]; + NSError *error = nil; + spfDict = [NSPropertyListSerialization propertyListWithData:data options:0 format:NULL error:&error]; + if (error) { + spfDict = nil; + } + } + } + + [[NSDistributedNotificationCenter defaultCenter] addObserver:self selector:@selector(externalApplicationWantsToOpenADatabaseConnection:) name:@"ExternalApplicationWantsToOpenADatabaseConnection" object:nil]; + // Set ourselves as the crash reporter delegate [[FRFeedbackReporter sharedReporter] setDelegate:self]; @@ -151,7 +166,11 @@ // If no documents are open, open one if (![self frontDocument]) { [self newWindow:self]; - + + if (spfDict) { + [[self frontDocument] setState:spfDict]; + } + // Set autoconnection if appropriate if ([[NSUserDefaults standardUserDefaults] boolForKey:SPAutoConnectToDefault]) { [[self frontDocument] connect]; @@ -159,6 +178,37 @@ } } + +- (void)externalApplicationWantsToOpenADatabaseConnection:(NSNotification *)notification +{ + SPWindowController *frontController = nil; + + for (NSWindow *aWindow in [NSApp orderedWindows]) { + if ([[aWindow windowController] isMemberOfClass:[SPWindowController class]]) { + frontController = [aWindow windowController]; + break; + } + } + + // If no window was found or the front most window has no tabs, create a new one + if (!frontController || [[frontController valueForKeyPath:@"tabView"] numberOfTabViewItems] == 1) { + [self newWindow:self]; + // Open the spf file in a new tab if the tab bar is visible + } else if ([[frontController valueForKeyPath:@"tabView"] numberOfTabViewItems] != 1) { + if ([[frontController window] isMiniaturized]) [[frontController window] deminiaturize:self]; + [frontController addNewConnection:self]; + } + + NSDictionary *userInfo = [notification userInfo]; + NSString *MAMP_SPFVersion = [userInfo objectForKey:@"dataVersion"]; + if ([MAMP_SPFVersion isEqualToString:@"1"]) { + NSDictionary *spfStructure = [userInfo objectForKey:@"spfData"]; + if (spfStructure) { + [[self frontDocument] setState:spfStructure]; + } + } +} + /** * Menu item validation. */ |