X-Git-Url: https://git.yukkurigames.com/?p=enjoyable.git;a=blobdiff_plain;f=ConfigsController.m;h=17cf8fd6a3a9547a11733b514fb48ec8344ba6ae;hp=50861cf73f66f5b3cf37dd9ec01b44e62daee2af;hb=9584becb2e5469e8f482d73e6f0c9c3bf879e0db;hpb=19eadf9e688d8c087b47f83f8634593fddd641ac diff --git a/ConfigsController.m b/ConfigsController.m index 50861cf..17cf8fd 100644 --- a/ConfigsController.m +++ b/ConfigsController.m @@ -5,27 +5,31 @@ // Created by Sam McCall on 4/05/09. // +#import "ConfigsController.h" + +#import "ApplicationController.h" +#import "Config.h" +#import "ConfigsController.h" +#import "Target.h" +#import "TargetController.h" + @implementation ConfigsController { - NSMutableArray *configs; - Config *manualConfig; + NSMutableArray *_configs; + Config *manualConfig; } -@synthesize currentConfig; -@synthesize configs; - - (id)init { - if ((self = [super init])) { - configs = [[NSMutableArray alloc] init]; - currentConfig = [[Config alloc] init]; - currentConfig.name = @"(default)"; - manualConfig = currentConfig; - [configs addObject:currentConfig]; - } - return self; + if ((self = [super init])) { + _configs = [[NSMutableArray alloc] init]; + _currentConfig = [[Config alloc] initWithName:@"(default)"]; + manualConfig = _currentConfig; + [_configs addObject:_currentConfig]; + } + return self; } - (Config *)objectForKeyedSubscript:(NSString *)name { - for (Config *config in configs) + for (Config *config in _configs) if ([name isEqualToString:config.name]) return config; return nil; @@ -40,129 +44,124 @@ - (void)activateConfig:(Config *)config { if (!config) config = manualConfig; - if (currentConfig == config) - return; + if (_currentConfig == config) + return; manualConfig = config; - currentConfig = config; - [targetController reset]; - [removeButton setEnabled:configs[0] != config]; - [targetController load]; - [(ApplicationController *)[[NSApplication sharedApplication] delegate] configChanged]; - [tableView selectRowIndexes:[NSIndexSet indexSetWithIndex:[configs indexOfObject:config]] byExtendingSelection:NO]; + _currentConfig = config; + [removeButton setEnabled:_configs[0] != config]; + [targetController loadCurrent]; + [(ApplicationController *)[[NSApplication sharedApplication] delegate] configChanged]; + [tableView selectRowIndexes:[NSIndexSet indexSetWithIndex:[_configs indexOfObject:config]] byExtendingSelection:NO]; } - (IBAction)addPressed:(id)sender { - Config *newConfig = [[Config alloc] init]; - newConfig.name = @"untitled"; - [configs addObject:newConfig]; - [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; - [tableView reloadData]; - [tableView selectRowIndexes:[NSIndexSet indexSetWithIndex:configs.count - 1] byExtendingSelection:NO]; - [tableView editColumn:0 row:[configs count] - 1 withEvent:nil select:YES]; + Config *newConfig = [[Config alloc] initWithName:@"Untitled"]; + [_configs addObject:newConfig]; + [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; + [tableView reloadData]; + [tableView selectRowIndexes:[NSIndexSet indexSetWithIndex:_configs.count - 1] byExtendingSelection:NO]; + [tableView editColumn:0 row:_configs.count - 1 withEvent:nil select:YES]; } - (IBAction)removePressed:(id)sender { if (tableView.selectedRow == 0) return; - - Config *toRemove = configs[tableView.selectedRow]; - [configs removeObjectAtIndex:tableView.selectedRow]; - if (toRemove == currentConfig) - currentConfig = configs[0]; + Config *toRemove = _configs[tableView.selectedRow]; + [_configs removeObjectAtIndex:tableView.selectedRow]; + + if (toRemove == _currentConfig) + _currentConfig = _configs[0]; if (toRemove == manualConfig) - manualConfig = configs[0]; - - // remove all "switch to configuration" actions - for (Config *config in configs) { - NSMutableDictionary *entries = config.entries; - for (id key in entries) { - Target *target = entries[key]; - if ([target isKindOfClass:[TargetConfig class]] - && [(TargetConfig *)target config] == toRemove) - [entries removeObjectForKey: key]; - } - } - [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; - [tableView reloadData]; + manualConfig = _configs[0]; + + [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; + [tableView reloadData]; } -(void)tableViewSelectionDidChange:(NSNotification *)notify { if (tableView.selectedRow >= 0) - [self activateConfig:configs[tableView.selectedRow]]; + [self activateConfig:_configs[tableView.selectedRow]]; } - -- (id)tableView:(NSTableView *)view objectValueForTableColumn:(NSTableColumn *)column row:(int)index { - return [configs[index] name]; + +- (id)tableView:(NSTableView *)view objectValueForTableColumn:(NSTableColumn *)column row:(NSInteger)index { + return [_configs[index] name]; } -- (void)tableView:(NSTableView *)view setObjectValue:obj forTableColumn:(NSTableColumn *)col row:(int)index { - /* ugly hack so stringification doesn't fail */ - NSString* newName = [(NSString*)obj stringByReplacingOccurrencesOfString: @"~" withString: @""]; - [(Config *)configs[index] setName:newName]; - [targetController refreshConfigsPreservingSelection:YES]; - [tableView reloadData]; - [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; +- (void)tableView:(NSTableView *)view setObjectValue:(NSString *)obj forTableColumn:(NSTableColumn *)col row:(NSInteger)index { + [(Config *)_configs[index] setName:obj]; + [tableView reloadData]; + [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; } -- (int)numberOfRowsInTableView:(NSTableView*)table { - return [configs count]; +- (NSInteger)numberOfRowsInTableView:(NSTableView *)tableView { + return _configs.count; } -- (BOOL)tableView:(NSTableView *)view shouldEditTableColumn:(NSTableColumn *)column row:(int)index { - return index > 0; +- (BOOL)tableView:(NSTableView *)view shouldEditTableColumn:(NSTableColumn *)column row:(NSInteger)index { + return index > 0; } --(void) save { +- (void)save { + NSLog(@"Saving defaults."); [[NSUserDefaults standardUserDefaults] setObject:[self dumpAll] forKey:@"configurations"]; - [[NSUserDefaults standardUserDefaults] synchronize]; -} --(void) load { - [self loadAllFrom: [[NSUserDefaults standardUserDefaults] objectForKey:@"configurations"]]; -} - --(NSDictionary*) dumpAll { - NSMutableDictionary *envelope = [[NSMutableDictionary alloc] init]; - NSMutableArray* ary = [[NSMutableArray alloc] init]; - for(Config* config in configs) { - NSMutableDictionary* cfgInfo = [[NSMutableDictionary alloc] init]; - cfgInfo[@"name"] = [config name]; - NSMutableDictionary* cfgEntries = [[NSMutableDictionary alloc] init]; - for(id key in [config entries]) { - cfgEntries[key] = [[config entries][key]stringify]; - } - cfgInfo[@"entries"] = cfgEntries; - [ary addObject: cfgInfo]; - } - envelope[@"configurationList"] = ary; - return envelope; -} - --(void) loadAllFrom: (NSDictionary*) envelope{ - if(envelope == NULL) - return; - NSArray* ary = envelope[@"configurationList"]; - - NSMutableArray* newConfigs = [[NSMutableArray alloc] init]; - // have to do two passes in case config1 refers to config2 via a TargetConfig - for(int i=0; i<[ary count]; i++) { - Config* cfg = [[Config alloc] init]; - [cfg setName: ary[i][@"name"]]; - [newConfigs addObject: cfg]; - } - for(int i=0; i<[ary count]; i++) { - NSDictionary* dict = ary[i][@"entries"]; - for(id key in dict) { - [newConfigs[i] entries][key] = [Target unstringify: dict[key] withConfigList: newConfigs]; - } - } - +} + +- (void)load { + [self loadAllFrom:[[NSUserDefaults standardUserDefaults] objectForKey:@"configurations"]]; +} + +- (NSDictionary *)dumpAll { + NSMutableArray *ary = [[NSMutableArray alloc] initWithCapacity:_configs.count]; + for (Config *config in _configs) + [ary addObject:[config serialize]]; + NSUInteger current = _currentConfig ? [_configs indexOfObject:_currentConfig] : 0; + return @{ @"configurations": ary, @"selected": @(current) }; +} + +- (void)loadAllFrom:(NSDictionary*) envelope{ + NSArray *storedConfigs = envelope[@"configurations"]; + NSMutableArray* newConfigs = [[NSMutableArray alloc] initWithCapacity:storedConfigs.count]; + + // have to do two passes in case config1 refers to config2 via a TargetConfig + for (NSDictionary *storedConfig in storedConfigs) { + Config *cfg = [[Config alloc] initWithName:storedConfig[@"name"]]; + [newConfigs addObject:cfg]; + } + + for (unsigned i = 0; i < storedConfigs.count; ++i) { + NSDictionary *entries = storedConfigs[i][@"entries"]; + Config *config = newConfigs[i]; + for (id key in entries) + config.entries[key] = [Target targetDeserialize:entries[key] + withConfigs:newConfigs]; + } + if (newConfigs.count) { - configs = newConfigs; + unsigned current = [envelope[@"selected"] unsignedIntValue]; + if (current >= newConfigs.count) + current = 0; + _configs = newConfigs; [tableView reloadData]; - currentConfig = configs[0]; - manualConfig = configs[0]; [(ApplicationController *)[[NSApplication sharedApplication] delegate] configsChanged]; + [self activateConfig:_configs[current]]; + } +} + +- (void)exportPressed:(id)sender { + NSSavePanel *panel = [NSSavePanel savePanel]; + panel.allowedFileTypes = @[ @"enjoyable" ]; + if ([panel runModal] == NSFileHandlingPanelOKButton) { + NSError *error; + NSDictionary *serialization = [_currentConfig serialize]; + NSData *json = [NSJSONSerialization dataWithJSONObject:serialization + options:NSJSONWritingPrettyPrinted + error:&error]; + if (!error) + [json writeToURL:panel.URL options:NSDataWritingAtomic error:&error]; + + if (error) + [[NSAlert alertWithError:error] runModal]; } }