X-Git-Url: https://git.yukkurigames.com/?p=enjoyable.git;a=blobdiff_plain;f=ConfigsController.m;h=fb50bc32c163c5f29114e5a6468583be1402fc91;hp=1c100f2c9809949a2976913646ba0a391a68974c;hb=1700c86669723045bf7abd177ca519f47656e995;hpb=f9903acac24bb4be43e370d5f3eb942510f727e1 diff --git a/ConfigsController.m b/ConfigsController.m index 1c100f2..fb50bc3 100644 --- a/ConfigsController.m +++ b/ConfigsController.m @@ -12,6 +12,7 @@ #import "ConfigsController.h" #import "Target.h" #import "TargetController.h" +#import "NJEvents.h" @implementation ConfigsController { NSMutableArray *_configs; @@ -37,20 +38,24 @@ - (void)activateConfigForProcess:(NSString *)processName { Config *oldConfig = manualConfig; - [self activateConfig:self[processName]]; + Config *newConfig = self[processName]; + if (!newConfig) + newConfig = oldConfig; + if (newConfig != _currentConfig) + [self activateConfig:newConfig]; manualConfig = oldConfig; } - (void)activateConfig:(Config *)config { if (!config) config = manualConfig; - if (_currentConfig == config) - return; + NSLog(@"Switching to mapping %@.", config.name); manualConfig = config; _currentConfig = config; [removeButton setEnabled:_configs[0] != config]; [targetController loadCurrent]; - [(ApplicationController *)NSApplication.sharedApplication.delegate configChanged]; + [NSNotificationCenter.defaultCenter postNotificationName:NJEventMappingChanged + object:_currentConfig]; [tableView selectRowIndexes:[NSIndexSet indexSetWithIndex:[_configs indexOfObject:config]] byExtendingSelection:NO]; } @@ -61,6 +66,7 @@ [tableView reloadData]; [tableView selectRowIndexes:[NSIndexSet indexSetWithIndex:_configs.count - 1] byExtendingSelection:NO]; [tableView editColumn:0 row:_configs.count - 1 withEvent:nil select:YES]; + [self activateConfig:newConfig]; } - (IBAction)removePressed:(id)sender { @@ -98,7 +104,7 @@ } - (void)save { - NSLog(@"Saving defaults."); + NSLog(@"Saving mappings to defaults."); [NSUserDefaults.standardUserDefaults setObject:[self dumpAll] forKey:@"configurations"]; } @@ -155,18 +161,25 @@ [stream close]; if (!([serialization isKindOfClass:NSDictionary.class] - && serialization[@"entries"])) { + && [serialization[@"name"] isKindOfClass:NSString.class] + && [serialization[@"entries"] isKindOfClass:NSDictionary.class])) { *error = [NSError errorWithDomain:@"Enjoyable" - code:0 - description:@"This isn't a valid mapping file."]; + code:0 + description:@"This isn't a valid mapping file."]; return nil; } NSDictionary *entries = serialization[@"entries"]; Config *cfg = [[Config alloc] initWithName:serialization[@"name"]]; - for (id key in entries) - cfg.entries[key] = [Target targetDeserialize:entries[key] - withConfigs:_configs]; + for (id key in entries) { + NSDictionary *value = entries[key]; + if ([key isKindOfClass:NSString.class]) { + Target *target = [Target targetDeserialize:value + withConfigs:_configs]; + if (target) + cfg.entries[key] = target; + } + } return cfg; } @@ -187,7 +200,8 @@ BOOL conflict; Config *mergeInto = self[cfg.name]; for (id key in cfg.entries) { - if (mergeInto.entries[key]) { + if (mergeInto.entries[key] + && ![mergeInto.entries[key] isEqual:cfg.entries[key]]) { conflict = YES; break; } @@ -231,10 +245,11 @@ } if (error) { - [[NSAlert alertWithError:error] beginSheetModalForWindow:window - modalDelegate:nil - didEndSelector:nil - contextInfo:nil]; + [window presentError:error + modalForWindow:window + delegate:nil + didPresentSelector:nil + contextInfo:nil]; } }]; @@ -248,27 +263,23 @@ NSWindow *window = NSApplication.sharedApplication.keyWindow; [panel beginSheetModalForWindow:window completionHandler:^(NSInteger result) { - if (result == NSFileHandlingPanelOKButton) { - NSError *error; - NSDictionary *serialization = [cfg serialize]; - NSData *json = [NSJSONSerialization dataWithJSONObject:serialization - options:NSJSONWritingPrettyPrinted - error:&error]; - if (!error) - [json writeToURL:panel.URL options:NSDataWritingAtomic error:&error]; - - if (error) { - // FIXME: Ideally, this sheet is attached to the - // panel, and the panel doesn't close, so you - // can maybe fix what is wrong and try saving - // again. But it seems to be impossible to force - // the panel to stay open. - [panel close]; - [[NSAlert alertWithError:error] beginSheetModalForWindow:window - modalDelegate:nil - didEndSelector:nil - contextInfo:nil]; - } + if (result != NSFileHandlingPanelOKButton) + return; + [panel close]; + NSError *error; + NSDictionary *serialization = [cfg serialize]; + NSData *json = [NSJSONSerialization dataWithJSONObject:serialization + options:NSJSONWritingPrettyPrinted + error:&error]; + if (!error) + [json writeToURL:panel.URL options:NSDataWritingAtomic error:&error]; + + if (error) { + [window presentError:error + modalForWindow:window + delegate:nil + didPresentSelector:nil + contextInfo:nil]; } }]; }