Подтвердить что ты не робот

Можно ли переопределить геттеры и сеттеры для @динамических свойств в подклассе NSManagedObject?

Итак, мой сценарий таков:

У меня есть подкласс NSManagedObject в моем приложении iOS, и в качестве свойства я хочу сохранить содержимое объекта MKPolygon. То, как я решил это сделать (и действительно ли это, пожалуй, другой вопрос), состоит в том, чтобы объявить свойство polygon как преобразуемый объект, а затем сохранить NSArray, содержащий точки многоугольника (как объект NSValue).

С этой целью я написал несколько методов класса удобства для моего объекта модели:

+ (NSArray *)coordsArrayFromMKPolygon:(MKPolygon *)polygon pointCount:(int)count
{
    CLLocationCoordinate2D *coords = (CLLocationCoordinate2D *)malloc(sizeof(CLLocationCoordinate2D) * count);
    [polygon getCoordinates:coords range:NSMakeRange(0, count)];
    NSMutableArray *coordsArray = [NSMutableArray array];
    for (int i = 0; i < count; i++) {
        NSValue *coordVal = [NSValue valueWithBytes:&coords[i] objCType:@encode(CLLocationCoordinate2D)];
        [coordsArray addObject:coordVal];
    }
    free(coords);
    return [NSArray arrayWithArray:coordsArray];
}

+ (MKPolygon *)polygonFromCoordsArray:(NSArray *)coordsArray pointCount:(int)count
{
    CLLocationCoordinate2D *coords = (CLLocationCoordinate2D *)malloc(sizeof(CLLocationCoordinate2D) * count);
    for (int i = 0; i < count; i++) {
        CLLocationCoordinate2D coord;
        [[coordsArray objectAtIndex:i] getValue:&coord];
        coords[i] = coord;
    }
    free(coords);
    return [MKPolygon polygonWithCoordinates:coords count:count];
}

Я могу просто вызвать эти методы на своих объектах MKPolygon, прежде чем сохранять или загружать экземпляр модели, но я бы хотел переопределить динамические геттеры и сеттеры в самой модели, так что я могу просто сказать что-то вроде [turf setTurf_bounds:polygon] (где многоугольник является экземпляром MKPolygon).

Мне бы очень хотелось, чтобы я мог сделать что-то вроде этого:

- (void)setTurf_bounds:(id)turf_bounds
{
    MKPolygon *poly = (MKPolygon *)turf_bounds;
    NSArray *coordsArray = [Turf coordsArrayFromMKPolygon:poly pointCount:[poly pointCount]];
    // Save the converted value into the @dynamic turf_bounds property
}

- (id)turf_bounds
{
    // grab the contents of the @dynamic turf_bounds property into say, NSArray *coordsArray
    return [Turf polygonFromCoordsArray:coordsArray pointCount:[coordsArray count]];
}

Но до сих пор у меня не было радости. Вызов [super setValue:coordsArray forKey:@"turf_bounds"] или его получатель-аналог не работает, и не пытается написать его как self.turf_bounds (который просто рекурсивно вызывает мои переопределенные сеттеры).

Я об этом совершенно неправильно, или что-то не хватает?

4b9b3361

Ответ 1

Никогда не вызывайте [super valueForKey:..] в подкласс NSManagedObject! (если вы не внедрили их в суперкласс) Вместо этого используйте примитивные методы доступа.

Пример реализации приемника/сеттера из ADC:

@interface Department : NSManagedObject
@property(nonatomic, strong) NSString *name;
@end

@interface Department (PrimitiveAccessors)
- (NSString *)primitiveName;
- (void)setPrimitiveName:(NSString *)newName;
@end


@implementation Department

@dynamic name;

- (NSString *)name
{
    [self willAccessValueForKey:@"name"];
    NSString *myName = [self primitiveName];
    [self didAccessValueForKey:@"name"];
    return myName;
}

- (void)setName:(NSString *)newName
{
    [self willChangeValueForKey:@"name"];
    [self setPrimitiveName:newName];
    [self didChangeValueForKey:@"name"];
}

@end