Dopasuj wiele klas przypadków w scali

Robię dopasowywanie do niektórych klas przypadków i chciałbym obsługiwać dwa przypadki w ten sam sposób. Coś takiego:

abstract class Foo
case class A extends Foo
case class B(s:String) extends Foo
case class C(s:String) extends Foo


def matcher(l: Foo): String = {
  l match {
    case A() => "A"
    case B(sb) | C(sc) => "B"
    case _ => "default"
  }
}

Ale kiedy to robię, pojawia się błąd:

(fragment of test.scala):10: error: illegal variable in pattern alternative
    case B(sb) | C(sc) => "B"

Mogę to zrobić. Usuwam parametry z definicji B i C, ale jak mogę dopasować je do params?

questionAnswers(3)

yourAnswerToTheQuestion