Я только недавно начал изучать scala, и сегодня я решил, что хочу написать парсер CSV, который будет хорошо загружаться в классы case, но хранить данные в строках (списках) объекта HList Shapeless, чтобы я мог немного познакомиться с программированием на уровне типов.
Вот что у меня есть на данный момент:
// LoadsCsv.scala
import shapeless._
import scala.collection.mutable
trait LoadsCsv[A, T <: HList] {
val rows: mutable.MutableList[T] = new mutable.MutableList[T]
def convert(t: T)(implicit gen: Generic.Aux[A, T]): A = gen.from(t)
def get(index: Int): A = {
convert(rows(index))
}
def load(file: String): Unit = {
val lines = io.Source.fromFile(file).getLines()
lines.foreach(line => rows += parse(line.split(",")))
}
def parse(line: Array[String]): T
}
И объект, загружающий набор данных:
// TennisData.scala
import shapeless._
case class TennisData(weather:String, low:Int, high:Int, windy:Boolean, play:Boolean)
object TennisData extends LoadsCsv[TennisData, String :: Int :: Int :: Boolean :: Boolean :: HNil] {
load("tennis.csv")
override def parse(line: Array[String]) = {
line(0) :: line(1).toInt :: line(2).toInt :: line(3).toBoolean :: line(4).toBoolean :: HNil
}
}
Кажется, что все работает нормально, пока я не добавил get () с преобразованием из HList в класс case, где теперь я получаю ошибку компиляции. Почему неявная загрузка не загружается и что я могу сделать, чтобы исправить это или иным образом преобразовать из HList в класс case?
Error:(14, 17) could not find implicit value for parameter gen: shapeless.Generic.Aux[A,T]
return convert(rows(index))
^
Я читал документацию shapeless и там упоминается, что эта область находилась в постоянном движении между версиями 1 и 2, но я считаю, что следует работать над моей версией shapeless и scala, поэтому я подозреваю, что ' я только что сделал что-то неправильно.
Для справки, я запускаю scala 2.11.6 и shapeless 2.2.2