Execute a seguinte função:
def fMatch(s: String) = {
s match {
case "a" => println("It was a")
case _ => println("It was something else")
}
}
Este padrão combina perfeitamente:
scala> fMatch("a")
It was a
scala> fMatch("b")
It was something else
O que eu gostaria de poder fazer é o seguinte:
def mMatch(s: String) = {
val target: String = "a"
s match {
case target => println("It was" + target)
case _ => println("It was something else")
}
}
Isso dá o seguinte erro:
fMatch: (s: String)Unit
<console>:12: error: unreachable code
case _ => println("It was something else")
Acho que é porque ele pensa que o destino é na verdade um nome que você gostaria de atribuir a qualquer que seja a entrada. Duas questões:
Por que esse comportamento? Não é possível apenas procurar variáveis existentes no escopo que tenham o tipo apropriado e usá-las primeiro e, se nenhuma for encontrada, tratar o alvo como um nome para o padrão de correspondência?
Existe uma solução alternativa para isso? Alguma maneira de combinar padrões com variáveis? No final das contas, pode-se usar uma instrução if grande, mas a caixa de correspondência é mais elegante.