Scala aplanar la lista

Quiero escribir una función que haga una lista de planos.

object Flat {
  def flatten[T](list: List[T]): List[T] = list match {
    case Nil => Nil
    case head :: Nil => List(head)
    case head :: tail => (head match {
      case l: List[T] => flatten(l)
      case i => List(i)
    }) ::: flatten(tail)
  }
}

object Main {
  def main(args: Array[String]) = {
    println(Flat.flatten(List(List(1, 1), 2, List(3, List(5, 8)))))
  }
}

No sé por qué no funciona, vuelve.List(1, 1, 2, List(3, List(5, 8))) pero debería serList(1, 1, 2, 3, 5, 8).

¿Podrías darme una pista?

Respuestas a la pregunta(4)

Su respuesta a la pregunta