Con queste definizioni:
trait Inspector[-C, -T] {
def contains(collection: C, value: T): Boolean
}
implicit def seqInspector[T, C <: SeqLike[Any, _]] = new Inspector[C, T]{
override def contains(collection: C, value: T): Boolean = collection.contains(value)
}
implicit def setInspector[T, C <: Set[T]] = new Inspector[C, T] {
override def contains(collection: C, value: T): Boolean = collection.contains(value)
}
implicit class MemberOps[T](t: T) {
def in[C](coll: C)(implicit inspector: Inspector[C, T]) =
inspector.contains(coll, t)
}
Si può fare controlli come questi:
2 in List(1, 2, 4) // true
2 in List("foo", 2) // true
2 in Set("foo", 2) // true
2 in Set(1, 3) // false
2 in Set("foo", "foo") // does not compile
2 in List("foo", "foo") // false (contains on a list is not the same as contains on a set)
2 in (0 to 10) // true
Quindi il codice necessario sarebbe:
val m = x in (0 to 10)
fonte
2014-09-26 12:47:52
noti che scrivendo "0 fino al 10" intendi 0, 1, 2,. .., 9 (compreso 0, escluso 10). Se si desidera includere 10, utilizzare "0 a 10". – Jesper
Vedere una domanda di stackoverflow correlata: [Come posso eseguire lo schema di corrispondenza su un intervallo in Scala?] (Http://stackoverflow.com/questions/3160888/how-can-i-pattern-match-on-a-range-in -scala) –
Il titolo chiede come abbinare un valore di tipo 'Range' a diverse possibilità, ad es. "Ho' (0..5) 'o' (1..6) '?" – Raphael