2015-01-14 20 views
5

Quindi, sto provando a utilizzare parboiled2 per le ultime settimane, è probabilmente la dipendenza più difficile da aggiungere a una build I mi sono imbattuto in tutta la mia vita Il mio errore di corrente è una compilazione sbt assembly) errore:Parboiled2 fa sì che venga rilevata una dipendenza mancante o non valida durante il caricamento del file di classe 'Prepender.class' "

[error] missing or invalid dependency detected while loading class file 'Prepender.class'. 
[error] Could not access type PrependAux in package shapeless, 
[error] because it (or its dependencies) are missing. Check your build definition for 
[error] missing or conflicting dependencies. (Re-run with `-Ylog-classpath` to see the problematic classpath.) 
[error] A full rebuild may help if 'Prepender.class' was compiled against an incompatible version of shapeless. 
[error] .../Main.scala:56: could not find implicit value for parameter prepender: spray.routing.Prepender[shapeless.HNil,shapeless.::[String,shapeless.HNil]] 
[error]  path(searchSegment/Segment)(title => get(responder(complete(
[error]      ^

Sembra che è semplicemente impossibile fare Spray e Parboiled2 bel gioco insieme.

Ho provato sbt clean e rimosso le mie directory target. Il mio file di configurazione è fondamentalmente questo:

resolvers ++= Seq(
    "spray repo" at "http://repo.spray.io" 
) 

val akkaV = "2.3.6" 
val sprayV = "1.3.2" 

libraryDependencies ++= Seq(
    // If I comment this line, everything works fine. 
    "org.parboiled" %% "parboiled" % "2.0.1" withSources() withJavadoc(), 
    // 
    "org.scalacheck" %% "scalacheck" % "1.12.1" % "test" withSources() withJavadoc(), 
    "org.specs2" %% "specs2-core" % "2.4.15" % "test" withSources() withJavadoc(), 
    "org.specs2" %% "specs2-scalacheck" % "2.4.15" % "test" withSources() withJavadoc(), 
    "org.scalaz" %% "scalaz-core" % "7.1.0" withSources() withJavadoc(), 
    // 
    "io.spray" %% "spray-json" % "1.3.1" withSources() withJavadoc(), 
    "io.spray" %% "spray-can" % sprayV withSources() withJavadoc(), 
    "io.spray" %% "spray-routing" % sprayV withSources() withJavadoc(), 
    "io.spray" %% "spray-testkit" % sprayV % "test" withSources() withJavadoc(), 
    // 
    "com.typesafe.akka" %% "akka-actor" % akkaV withSources() withJavadoc(), 
    "com.typesafe.akka" %% "akka-testkit" % akkaV % "test" withSources() withJavadoc() 
) 

scalaVersion := "2.11.4" 

javaOptions ++= Seq("-target", "1.8", "-source", "1.8") 

mio sbtVersion è 0.13.6, e la mia versione sbt-assembly è 0.12.0

Prima di eseguire l'aggiornamento a 2.11 e l'aggiornamento mie dipendenze specs2 ho ottenuto: parboiled2 and Spray cause conflicting cross-version suffixes

risposta