X-Git-Url: https://git.yukkurigames.com/?p=enjoyable.git;a=blobdiff_plain;f=Target.m;h=097562e52f3237a5b4788d19132a33476e6c6aef;hp=6b208e8785626f9d4f27614b36a709f7b3baaa2c;hb=e2a4d830dd9817f6a515a3b1b6aa152d3bb98c2b;hpb=c6fb77859e508aaef686b7a5a6a12abe29178708 diff --git a/Target.m b/Target.m index 6b208e8..097562e 100644 --- a/Target.m +++ b/Target.m @@ -18,33 +18,43 @@ BOOL running; } -@synthesize magnitude; - -// TODO: Should just be NSCoding? Or like a dictionary? -+(Target*) unstringify: (NSString*) str withConfigList: (NSArray*) configs { - NSArray* components = [str componentsSeparatedByString:@"~"]; - NSParameterAssert([components count]); - NSString* typeTag = components[0]; - if([typeTag isEqualToString:@"key"]) - return [TargetKeyboard unstringifyImpl:components]; - if([typeTag isEqualToString:@"cfg"]) - return [TargetConfig unstringifyImpl:components withConfigList:configs]; - if([typeTag isEqualToString:@"mmove"]) - return [TargetMouseMove unstringifyImpl:components]; - if([typeTag isEqualToString:@"mbtn"]) - return [TargetMouseBtn unstringifyImpl:components]; - if([typeTag isEqualToString:@"mscroll"]) - return [TargetMouseScroll unstringifyImpl:components]; - if([typeTag isEqualToString:@"mtoggle"]) - return [TargetToggleMouseScope unstringifyImpl:components]; - - NSParameterAssert(NO); - return NULL; ++ (NSString *)serializationCode { + [self doesNotRecognizeSelector:_cmd]; + return nil; } -- (NSString *)stringify { +- (NSDictionary *)serialize { [self doesNotRecognizeSelector:_cmd]; - return NULL; + return nil; +} + +- (BOOL)isEqual:(id)object { + return [object isKindOfClass:Target.class] + && [[self serialize] isEqual:[object serialize]]; +} + +- (NSUInteger)hash { + return [[self serialize] hash]; +} + ++ (Target *)targetDeserialize:(NSDictionary *)serialization + withMappings:(NSArray *)mappings { + // Don't crash loading old/bad mappings (but don't load them either). + if (![serialization isKindOfClass:NSDictionary.class]) + return nil; + NSString *type = serialization[@"type"]; + for (Class cls in @[TargetKeyboard.class, + TargetConfig.class, + TargetMouseMove.class, + TargetMouseBtn.class, + TargetMouseScroll.class, + TargetToggleMouseScope.class + ]) { + if ([type isEqualToString:cls.serializationCode]) + return [cls targetDeserialize:serialization withMappings:mappings]; + } + + return nil; } - (void)trigger { @@ -53,7 +63,7 @@ - (void)untrigger { } -- (BOOL)update:(JoystickController *)jc { +- (BOOL)update:(NJInputController *)jc { return NO; }