correspondência de padrão em uma série de valores em scala
-
05-07-2019 - |
Pergunta
Eu sou um novato Scala e este pedaço de código faz-me luta.
Existe uma maneira de fazer a correspondência de padrões para garantir que tudo i passar para dados é do tipo correto? Como você pode ver eu tenho tipos de dados muito estranho ...
class Data (
val recipient: String,
val templateText: String,
val templateHtml: String,
val blockMaps: Map[String,List[Map[String,String]]],
templateMap: Map[String,String]
)
...
val dataParsed = JSON.parseFull(message)
dataParsed match {
case dataParsed: Map[String, Any] => {
def e(s: String) = dataParsed get s
val templateText = e("template-text")
val templateHtml = e("template-html")
val recipient = e("email")
val templateMap = e("data")
val blockMaps = e("blkdata")
val dependencies = new Data(recipient, templateText, templateHtml, blockMaps, templateMap)
Core.inject ! dependencies
}
...
Solução
Eu acho que o problema é que você quer ser capaz de Patten coincidir com o mapa que você começa a partir parseFull()
, mas o mapa não tem um unapply
.
Então, você poderia padrão de combinar cada valor único, proporcionando um padrão que não seja do tipo correto:
val templateText: Option[String] = e("template-text") match {
case s: String => Some(s)
case _ => None
}
Ou colocar temporariamente todos os dados em uma estrutura que pode ser padrão combinado:
val data = (e("template-text"), e("template-html"), e("email"), e("data"),
e("blkdata"))
val dependencies: Option[Data] = data match {
case (templateText: String,
templateHtml: String,
blockMaps: Map[String,List[Map[String,String]]],
templateMap: Map[String,String]) =>
Some(new Data(recipient, templateText, templateHtml, blockMaps, templateMap))
case _ => None
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow