Приведена иерархия типов для игры, которая четко различает, чей ход следующий:
trait Game
trait BlackToPlay extends Game {
def move(p: BlackPiece, s: Square): Either[FinishedGame, WhiteToPlay]
}
trait WhiteToPlay extends Game {
def move(p: WhitePiece, s: Square): Either[FinishedGame, BlackToPlay]
}
Можно ли сделать следующее важное утверждение, не прибегая к размышлениям?
"A game with white to play" should {
"not allow black to play" in {
// an instance of whiteToPlay should not
// have the `move(BlackPiece, Square)` method.
}
}
РЕДАКТИРОВАТЬ: Моя попытка реализовать решение @ Martin не работает. Есть мысли о том, что здесь не так? Из отчета:
scala> class B() {
| def b(s: String) = s
| }
defined class B
scala> val b = new B()
b: B = B@420e44
scala> b.c("")
<console>:8: error: value c is not a member of B
b.c("")
^
scala> b match {
| case _: { def c(s: String) } => false
| case _ => true
| }
warning: there were unchecked warnings; re-run with -unchecked for details
res7: Boolean = false
res7
должно быть верным, потому что b
не должен совпадать с типом структуры { def c(s: String) }