Skip to content

Commit

Permalink
Merge pull request rentzsch#86 from robrix/mogenerator
Browse files Browse the repository at this point in the history
---

It is usable as a replacement for both -scalarAttributeType and -objectAttributeType, and pulls from the attributeValueTypeName userInfo field if available.
  • Loading branch information
rentzsch committed Jan 7, 2012
2 parents 9a7d37f + a753e19 commit 636604b
Show file tree
Hide file tree
Showing 4 changed files with 98 additions and 16 deletions.
4 changes: 4 additions & 0 deletions mogenerator.h
Original file line number Diff line number Diff line change
Expand Up @@ -30,8 +30,12 @@
@interface NSAttributeDescription (scalarAttributeType)
- (BOOL)hasScalarAttributeType;
- (NSString*)scalarAttributeType;
- (NSString*)scalarAttributeTypeName;
- (NSString*)scalarAccessorMethodName;
- (NSString*)scalarFactoryMethodName;
- (BOOL)hasDefinedAttributeType;
- (NSString*)objectAttributeType;
- (NSString*)attributeTypeName;
- (BOOL)hasTransformableAttributeType;
@end

Expand Down
78 changes: 78 additions & 0 deletions mogenerator.m
Original file line number Diff line number Diff line change
Expand Up @@ -248,6 +248,78 @@ - (NSString*)scalarAttributeType {
return nil;
}
}
- (NSString*)scalarAttributeTypeName {
switch ([self attributeType]) {
case NSInteger16AttributeType:
return @"int16_t";
break;
case NSInteger32AttributeType:
return @"int32_t";
break;
case NSInteger64AttributeType:
return @"int64_t";
break;
case NSDoubleAttributeType:
return @"double";
break;
case NSFloatAttributeType:
return @"float";
break;
case NSBooleanAttributeType:
return @"BOOL";
break;
default:
return nil;
}
}
- (NSString*)scalarAccessorMethodName {
switch ([self attributeType]) {
case NSInteger16AttributeType:
return @"shortValue";
break;
case NSInteger32AttributeType:
return @"intValue";
break;
case NSInteger64AttributeType:
return @"longLongValue";
break;
case NSDoubleAttributeType:
return @"doubleValue";
break;
case NSFloatAttributeType:
return @"floatValue";
break;
case NSBooleanAttributeType:
return @"boolValue";
break;
default:
return nil;
}
}
- (NSString*)scalarFactoryMethodName {
switch ([self attributeType]) {
case NSInteger16AttributeType:
return @"numberWithShortValue:";
break;
case NSInteger32AttributeType:
return @"numberWithIntValue:";
break;
case NSInteger64AttributeType:
return @"numberWithLongLongValue:";
break;
case NSDoubleAttributeType:
return @"numberWithDoubleValue:";
break;
case NSFloatAttributeType:
return @"numberWithFloatValue:";
break;
case NSBooleanAttributeType:
return @"numberWithBoolValue:";
break;
default:
return nil;
}
}
- (BOOL)hasDefinedAttributeType {
return [self attributeType] != NSUndefinedAttributeType;
}
Expand All @@ -259,6 +331,12 @@ - (NSString*)objectAttributeType {
return [self attributeValueClassName];
}
}
- (NSString*)attributeTypeName {
return
[[self userInfo] objectForKey:@"attributeValueTypeName"]
?: [self scalarAttributeTypeName]
?: [[self objectAttributeType] stringByAppendingString:@"*"];
}

- (BOOL)hasTransformableAttributeType {
return ([self attributeType] == NSTransformableAttributeType);
Expand Down
18 changes: 9 additions & 9 deletions templates/machine.h.motemplate
Original file line number Diff line number Diff line change
Expand Up @@ -32,14 +32,14 @@ extern const struct <$managedObjectClassName$>FetchedProperties {<$foreach Fetch
<$foreach Attribute noninheritedAttributes do$>
<$if Attribute.hasDefinedAttributeType$>
<$if TemplateVar.arc$>
@property (nonatomic, strong) <$Attribute.objectAttributeType$> *<$Attribute.name$>;
@property (nonatomic, strong) <$Attribute.attributeTypeName$> <$Attribute.name$>;
<$else$>
@property (nonatomic, retain) <$Attribute.objectAttributeType$> *<$Attribute.name$>;
@property (nonatomic, retain) <$Attribute.attributeTypeName$> <$Attribute.name$>;
<$endif$>
<$if Attribute.hasScalarAttributeType$>
@property <$Attribute.scalarAttributeType$> <$Attribute.name$>Value;
- (<$Attribute.scalarAttributeType$>)<$Attribute.name$>Value;
- (void)set<$Attribute.name.initialCapitalString$>Value:(<$Attribute.scalarAttributeType$>)value_;
@property <$Attribute.attributeTypeName$> <$Attribute.name$>Value;
- (<$Attribute.attributeTypeName$>)<$Attribute.name$>Value;
- (void)set<$Attribute.name.initialCapitalString$>Value:(<$Attribute.attributeTypeName$>)value_;
<$endif$>
//- (BOOL)validate<$Attribute.name.initialCapitalString$>:(id*)value_ error:(NSError**)error_;
<$endif$>
Expand Down Expand Up @@ -87,11 +87,11 @@ extern const struct <$managedObjectClassName$>FetchedProperties {<$foreach Fetch
@interface _<$managedObjectClassName$> (CoreDataGeneratedPrimitiveAccessors)
<$foreach Attribute noninheritedAttributes do$>
<$if Attribute.hasDefinedAttributeType$>
- (<$Attribute.objectAttributeType$>*)primitive<$Attribute.name.initialCapitalString$>;
- (void)setPrimitive<$Attribute.name.initialCapitalString$>:(<$Attribute.objectAttributeType$>*)value;
- (<$Attribute.attributeTypeName$>)primitive<$Attribute.name.initialCapitalString$>;
- (void)setPrimitive<$Attribute.name.initialCapitalString$>:(<$Attribute.attributeTypeName$>)value;
<$if Attribute.hasScalarAttributeType$>
- (<$Attribute.scalarAttributeType$>)primitive<$Attribute.name.initialCapitalString$>Value;
- (void)setPrimitive<$Attribute.name.initialCapitalString$>Value:(<$Attribute.scalarAttributeType$>)value_;
- (<$Attribute.attributeTypeName$>)primitive<$Attribute.name.initialCapitalString$>Value;
- (void)setPrimitive<$Attribute.name.initialCapitalString$>Value:(<$Attribute.attributeTypeName$>)value_;
<$endif$>
<$endif$>
<$endforeach do$>
Expand Down
14 changes: 7 additions & 7 deletions templates/machine.m.motemplate
Original file line number Diff line number Diff line change
Expand Up @@ -56,22 +56,22 @@ const struct <$managedObjectClassName$>FetchedProperties <$managedObjectClassNam

<$if Attribute.hasScalarAttributeType$>

- (<$Attribute.scalarAttributeType$>)<$Attribute.name$>Value {
- (<$Attribute.attributeTypeName$>)<$Attribute.name$>Value {
NSNumber *result = [self <$Attribute.name$>];
return [result <$Attribute.scalarAttributeType.camelCaseString$>Value];
return [result <$Attribute.scalarAttributeAccessorMethod$>];
}

- (void)set<$Attribute.name.initialCapitalString$>Value:(<$Attribute.scalarAttributeType$>)value_ {
[self set<$Attribute.name.initialCapitalString$>:[NSNumber numberWith<$Attribute.scalarAttributeType.camelCaseString.initialCapitalString$>:value_]];
- (void)set<$Attribute.name.initialCapitalString$>Value:(<$Attribute.attributeTypeName$>)value_ {
[self set<$Attribute.name.initialCapitalString$>:[NSNumber <$Attribute.scalarAttributeFactoryMethod$>value_]];
}

- (<$Attribute.scalarAttributeType$>)primitive<$Attribute.name.initialCapitalString$>Value {
- (<$Attribute.attributeTypeName$>)primitive<$Attribute.name.initialCapitalString$>Value {
NSNumber *result = [self primitive<$Attribute.name.initialCapitalString$>];
return [result <$Attribute.scalarAttributeType.camelCaseString$>Value];
return [result <$Attribute.scalarAttributeAccessorMethod$>];
}

- (void)setPrimitive<$Attribute.name.initialCapitalString$>Value:(<$Attribute.scalarAttributeType$>)value_ {
[self setPrimitive<$Attribute.name.initialCapitalString$>:[NSNumber numberWith<$Attribute.scalarAttributeType.camelCaseString.initialCapitalString$>:value_]];
[self setPrimitive<$Attribute.name.initialCapitalString$>:[NSNumber <$Attribute.scalarAttributeFactoryMethod$>value_]];
}
<$endif$>
<$endif$>
Expand Down

0 comments on commit 636604b

Please sign in to comment.