aboutsummaryrefslogtreecommitdiffstats
path: root/Source/SPAppController.m
diff options
context:
space:
mode:
authorAbhi Beckert <abhi@abhibeckert.com>2015-05-16 08:45:26 +1000
committerAbhi Beckert <abhi@abhibeckert.com>2015-05-16 08:45:26 +1000
commit57d0d4400d25265dee4e70376e8c9ab6b96e8f79 (patch)
tree921a781c919cfd3cfb3cf27e7509577e588e52cc /Source/SPAppController.m
parent0f0c43eb74408b6a65a42e2c6fd46f4142ef8e3f (diff)
parent7654a9f82f621cc668414fc0b632a92382f7e51c (diff)
downloadsequelpro-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.m52
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.
*/