X-Git-Url: https://git.yukkurigames.com/?p=enjoyable.git;a=blobdiff_plain;f=TargetConfig.m;h=e9c374ed5ec6d5df44e7dafd9c43c37f88750352;hp=469edabe0bb9898386c1705b9987b06361b34111;hb=15a3aec049658f4a1c3c6e8c9f8a549fb8de0782;hpb=d9d15b3f8729758f19b21918fee758b856921673 diff --git a/TargetConfig.m b/TargetConfig.m index 469edab..e9c374e 100644 --- a/TargetConfig.m +++ b/TargetConfig.m @@ -7,14 +7,25 @@ #import "TargetConfig.h" +#import "ApplicationController.h" +#import "Config.h" +#import "ConfigsController.h" + @implementation TargetConfig -- (NSString *)stringify { - return [[NSString alloc] initWithFormat: @"cfg~%@", self.config.name]; ++ (NSString *)serializationCode { + return @"cfg"; +} + +- (NSDictionary *)serialize { + return _config + ? @{ @"type": @"cfg", @"name": _config.name } + : @{}; } -+ (TargetConfig *)unstringifyImpl:(NSArray *)comps withConfigList:(NSArray *)configs { - NSString *name = comps[1]; ++ (TargetConfig *)targetDeserialize:(NSDictionary *)serialization + withConfigs:(NSArray *)configs { + NSString *name = serialization[@"name"]; TargetConfig *target = [[TargetConfig alloc] init]; for (Config *config in configs) { if ([config.name isEqualToString:name]) { @@ -22,12 +33,11 @@ return target; } } - NSLog(@"Warning: couldn't find matching config to restore from: %@", name); return nil; } - (void)trigger { - [[(ApplicationController *)[[NSApplication sharedApplication] delegate] configsController] activateConfig:self.config]; + [[(ApplicationController *)[[NSApplication sharedApplication] delegate] configsController] activateConfig:_config]; } @end