Swift Equatable Protocol

85

Śledziłem ten samouczek dla Swift: https://www.raywenderlich.com/125311/make-game-like-candy-crush-spritekit-swift-part-1 i natknąłem się na ten kod:

func == (lhs: Cookie, rhs: Cookie) -> Bool {
    return lhs.column == rhs.column && lhs.row == rhs.row
}

Napisałem dokładnie to, ale Xcode podaje mi te błędy:

Consecutive declarations on a line must be separated by ';'
Expected declaration operators are only allowed at global scope

Znalazłem ten kod w dokumentacji Apple: https://developer.apple.com/documentation/swift/equatable

Co jest bardzo podobne do tego, co napisałem. Co jest nie tak? Wydaje mi się, że to błąd. Używam Xcode 6 Beta 2

EDYTOWAĆ:

To jest cała moja klasa 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
    }
}
Addison
źródło
Jaki jest kod przed tym stwierdzeniem? Samo to działa dobrze
Connor,
Dodałem całą klasę do opisu
Addison
8
„deklaracja Operatory są dozwolone tylko w zakresie globalnym” Całkiem cholernie jasne. To jeden z lepszych komunikatów o błędach kompilatora Swift!
mat.
1
możesz przeciążyć operator tylko w zakresie plików .
holex
2
Musisz wyjść func ==(lhs: Cookie, rhs: Cookie) -> Bool {...}z klasy Cookie !!
Hlung

Odpowiedzi:

145

Przenieś tę funkcję

func == (lhs: Cookie, rhs: Cookie) -> Bool {
    return lhs.column == rhs.column && lhs.row == rhs.row
}

Poza klasą cookie. Ma to sens, ponieważ zastępuje operator == w zakresie globalnym, gdy jest używany na dwóch plikach cookie.

Connor
źródło
3
Chciałbym dodać, że w xCode 6.3.2 i swfit 1.2 func == musi znajdować się bezpośrednio po definicji klasy lub struktury. Nawet dodanie prostego zdania, takiego jak „var a = 1”, zwróci błąd kompilatora.
fangmobile
2
Nigdy bym nie pomyślał, aby umieścić go poza klasą! Jak to się w ogóle nazywa? Jak mogę to znaleźć w Google?
rr1g0
1
Istnieje wyjaśnienie, dlaczego przeciążenie operatora znajduje się w zakresie globalnym , chociaż omawiana jest możliwa zmiana, aby umożliwić implementację operatora wewnątrz typu.
32

SWIFT 2:

Jak w swift 2 NSObjectjuż się dostosowuje Equatable. Nie potrzebujesz zgodności na górze, więc jest tak

class Cookie: NSObject {
    ...

}

I musisz zastąpić isEqualmetodę jako

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
    }

}

Ta isEqualmetoda czasowa znajduje się wewnątrz klasy. :)

EDYCJA dla SWIFT 3: Zmień tę metodę na

override func isEqual(_ object: AnyObject?) -> Bool {
        guard let rhs = object as? Cookie else {
            return false
        }
        let lhs = self

        return lhs.column == rhs.column
    }
Anish Parajuli 웃
źródło
6

uczynienie z klasy obiektu NSObject rozwiązało za mnie możliwe do wyrównywania problemy ...

class Cookie: NSObject {
...
}

(wskazówka z samouczków dla uczniów na iOS)

Felipe Ignacio Noriega Alcaraz
źródło
1
Dzieje się tak, ponieważ NSObject implementuje następujący w linii 70 NSObject swiftDoc extension NSObject : Equatable, Hashable.
Adrian Sluyters,