Je suivais ce tutoriel pour Swift: https://www.raywenderlich.com/125311/make-game-like-candy-crush-spritekit-Swift-part-1 et suis tombé sur ce code:
func == (lhs: Cookie, rhs: Cookie) -> Bool {
return lhs.column == rhs.column && lhs.row == rhs.row
}
J'ai écrit exactement cela, mais Xcode me donne ces erreurs:
Consecutive declarations on a line must be separated by ';'
Expected declaration operators are only allowed at global scope
J'ai trouvé ce code dans la documentation d'Apple: https://developer.Apple.com/documentation/Swift/equatable
Ce qui est très similaire à ce que j'ai écrit. Qu'est-ce qui ne va pas? Cela semble être un bug pour moi. J'utilise Xcode 6 Beta 2
Ceci est toute ma classe Cookie:
class Cookie: Printable, Hashable {
var column: Int
var row: Int
let cookieType: CookieType
let Sprite: SKSpriteNode?
init(column: Int, row: Int, cookieType: CookieType) {
self.column = column
self.row = row
self.cookieType = cookieType
}
var description: String {
return "type:\(cookieType) square:(\(column),\(row))"
}
var hashValue: Int {
return row * 10 + column
}
func ==(lhs: Cookie, rhs: Cookie) -> Bool {
return lhs.column == rhs.column && lhs.row == rhs.row
}
}
Déplacer cette fonction
func == (lhs: Cookie, rhs: Cookie) -> Bool {
return lhs.column == rhs.column && lhs.row == rhs.row
}
En dehors de la classe de cookie. C'est logique dans ce sens car il remplace l'opérateur == au niveau global lorsqu'il est utilisé sur deux cookies.
Swift 2:
Comme dans Swift 2 NSObject
se conforme déjà à Equatable
. Vous n'avez pas besoin de conformité en haut, c'est comme
class Cookie: NSObject {
...
}
Et vous devez redéfinir la méthode isEqual
en tant que
class Cookie:NSObject{
var column: Int
var row: Int
//..........
override func isEqual(object: AnyObject?) -> Bool {
guard let rhs = object as? Cookie else {
return false
}
let lhs = self
return lhs.column == rhs.column
}
}
Cette fois, la méthode isEqual
est à l'intérieur de la classe. :)
EDIT for Swift 3: Modifiez cette méthode en tant que
override func isEqual(_ object: AnyObject?) -> Bool {
guard let rhs = object as? Cookie else {
return false
}
let lhs = self
return lhs.column == rhs.column
}
faire de la classe un objet NSObject a résolu pour moi les problèmes qui se posent en conséquence ...
class Cookie: NSObject {
...
}
(obtenu le conseil des tutoriels d'apprenti iOS)