сопоставление с образцом в серии значений в Scala - PullRequest
3 голосов
/ 27 ноября 2009

Я новичок в Scala, и этот кусок кода заставляет меня бороться.

Есть ли способ сопоставления с образцом, чтобы убедиться, что все, что я передаю в Данные, имеет правильный тип? Как видите, у меня довольно странные типы данных ...

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
 }

...

1 Ответ

1 голос
/ 27 ноября 2009

Полагаю, ваша проблема в том, что вы хотите иметь возможность сопоставлять карту с картой, полученной с parseFull(), но на карте нет unapply.

Таким образом, вы можете сопоставить шаблон с каждым отдельным значением, предоставив значение по умолчанию, если оно имеет неправильный тип:

val templateText: Option[String] = e("template-text") match {
  case s: String => Some(s)
  case _ => None
}

Или временно поместите все данные в некоторую структуру, которая может быть сопоставлена ​​с шаблоном:

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
}
...