Make sure you register the subclass in application:didFinishLaunchingWithOptions: In my case, it does not pass the extracted object as a subclass of PFObject.
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { Armor.registerSubclass() Parse.enableLocalDatastore() Parse.setApplicationId(..., clientKey: ...) return true }
AppDelegate.swift
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool { CatsObject.registerSubclass() Parse.enableLocalDatastore() Parse.setApplicationId("...", clientKey: "...") return true }
CatsObject.swift
import Foundation class CatsObject: PFObject, PFSubclassing { static func parseClassName() -> String { return "Cat" } }
CatViewController.swift
override func viewDidLoad() { queryData() } func queryData() { let query = PFQuery(className: CatsObject.parseClassName()) query.fromLocalDatastore() query.findObjectsInBackgroundWithBlock({ (objects:[AnyObject]?, error: NSError?) in if let error = error { // There was an error } else { println("count local objects = \(objects?.count)") if let objects = objects as? [PFObject] { for object in objects { println("PFObject object retrieved") if object is CatsObject { println("object is CatsObject subclass") } if let object = object as? CatsObject { println("PFObject object cast as CatsObject") } } } } }) }
Console exit
count local objects = Optional(10) PFObject object retrieved object is CatsObject subclass PFObject object cast as CatsObject
source share