Reputation: 53
Hi I have an exception like "Cannot specialize a non-generic definition" when i'm trying to initialize List in Realm object. Does anyone know how to fix this issue? swift 3.2
class Dog: Object {
@objc dynamic var name = ""
@objc dynamic var age = 0
}
class Event : Object{
dynamic var event_id = 0
dynamic var date : String?
dynamic var name : String?
dynamic var remind : Remind?
dynamic var event_status = 0
let dogs = List<Dog>() "Cannot specialize a non-generic definition"
required convenience init?(map: Map){ self.init() }
}
Upvotes: 5
Views: 1438
Reputation: 6622
I wanted to give the solution to this question some context. In Swift, namespacing is implicit on a module level. If you have external modules, such as RealmSwift, which has a type List
you can still have a type named List
in your own module. You can even have multiple external modules with the type List
.
My reasoning for the error you presented was as follows
List
sList
is a valid type and in fact knows about a function named List.init()
, however, the compiler is telling you that the function isn't generic.The only answer at that point, is to assume the compiler is using a different definition of List
than you are intending. The only way this happens is if the scope you're in (your project or another type), has also defined a type List
, since internal types take precedence over external types. This precedence is extended further with type nesting. If you'd like to keep Realm's List
as the default list, you can nest your List
in another structure to provide a namespace of sorts.
The following example is as concise as possible given the complex situation.
import RealmSwift
let myGlobalDogs = List()
let myGlobalNestedListDogs = MyClass.List()
let globalDogs = RealmSwift.List<Dog>()
class List { }
class MyClass {
class List { }
let dogs = RealmSwift.List<Dog>()
let myNestedListDogs = List() // type: MyModule.MyClass.List
let myDogs = MyModule.List() // type: MyModule.List
}
class MyOtherClass {
let dogs = RealmSwift.List<Dog>()
let myNestedListDogs = MyClass.List() // type: MyModule.MyClass.List
let myDogs = List() // type: MyModule.List
}
Fortunately, types/functions are usually different enough that you can't inadvertently use the wrong one without encountering an error eventually, such as the one you encountered.
Upvotes: 8