NSManagedObject上的Swift扩展

时间:2015-01-07 17:39:31

标签: swift nsmanagedobject swift-extensions

我可以在Objective-C中执行此操作,但我在查找如何使其在Swift中工作时遇到了麻烦。我在NSManagedObject上编写了一个扩展,这样我就可以随时调用一个函数来创建一个新实体。然后,该函数将检查现有实体是否匹配,如果没有匹配,该函数将创建新实体并将其返回。如果匹配,则返回匹配。这是我的代码:

extension Chapter {
    class func createChapter(i_d: Int, team_level: Int, location: String, name: String, school: String, image: UIImage, context: NSManagedObjectContext) -> Chapter {

        var chapter : Chapter?

        var request : NSFetchRequest = NSFetchRequest(entityName: "Chapter")
        request.predicate = NSPredicate(format: "i_d = \(i_d)")
        var error : NSError?
        var results : [Chapter] = context.executeFetchRequest(request, error: &error) as [Chapter]

        if error != nil{
            println(error)
        } else if results.count == 1 {
            println("Only found one Chapter match for id: \(i_d)")
            chapter = results.first!
        } else if results.count > 1 {
            println("Found multiple Chapters for id: \(i_d)")
            for chapter in results {
                println(chapter.name)
            }
        } else {
            chapter = NSEntityDescription.insertNewObjectForEntityForName("Chapter", inManagedObjectContext: context) as? Chapter
            chapter?.i_d = i_d
            chapter?.team_level = team_level
            chapter?.location = location
            chapter?.name = name
            chapter?.school = school
            chapter?.image = UIImagePNGRepresentation(image)

            var error: NSError? = nil
            if !context.save(&error) {
                println("Saving error \(error), \(error?.userInfo)")
            } else {
                println("Saved a Chapter with id: \(i_d)")
            }
        }

        return chapter!
    }
}
  • " i_d"是实体的唯一ID

这就是我以前在Objective-C(粗略翻译)中调用类似内容的方式:

Chapter *chapter = [Chapter createChapterWithID:i_d, team_level:team_level, location:location, name:name, school:school, image:image, context:context];

每当我尝试 var chap:Chapter = Chapter.createChapter(...)之类的东西时,Xcode只允许我在参数列表中放入另一个Chapter对象,而如果我尝试调用该函数从章节实例中,函数参数可以填写正确。

我将如何解决我的问题?

编辑:

根据答案建议,我通过放置" class"来修复我的代码。在我的函数定义前面,以及在函数中正确创建我的初始变量,并在必要的地方添加问号。

1 个答案:

答案 0 :(得分:1)

您可以尝试创建一个便利初始化。

http://devmonologue.com/ios/swift/swift-initializers-designated-convenience/

还要注意,如果你想做Chapter.createChapter(),createChapter需要是一个类func,在你的扩展中它只是一个常规的func。所以它期望章对象创建对象,而不是类。

更改

func createChapter ...

class func createChapter ...