Wie kann ich Gläser aus mehr als einem nicht verwalteten Verzeichnis in einer SBT -.Scala -Projektkonfiguration hinzufügen?
-
27-10-2019 - |
Frage
Ich versuche, SBT dazu zu bringen, ein Projekt zu erstellen, das mehr als ein unwirkliches Verzeichnis haben könnte. Wenn ich ein einzelnes Verzeichnis hätte, könnte ich es leicht so machen:
unmanagedBase := file( "custom-libs" ).getAbsoluteFile
Aber da ich zwei Verzeichnisse mit nicht verwalteten Gläser habe, muss ich sie alle hinzufügen können. Ich habe einige Informationen gefunden hier drin, aber immer noch nicht nützlich für meinen vollen .Scala Dateiaufbau.
Ich habe ein einfaches Projekt erstellt, das das Problem zeigt hier drin. Und unten ist mein Build.scala Datei.
AKTUALISIEREN
Ich habe etwas Hilfe SBT-User-Liste und konnten das definieren nicht verwaltete Jars richtig, aber der Code kompiliert immer noch nicht (aber SBT-Show Unmanaged-Jars Zeigt die Dateien richtig an).
import sbt._
import com.github.siasia._
import PluginKeys._
import Keys._
object Build extends sbt.Build {
import Dependencies._
val unmanagedListing = unmanagedJars := {
Dependencies.listUnmanaged( file(".").getAbsoluteFile )
}
lazy val myProject = Project("spray-template", file("."))
.settings(WebPlugin.webSettings: _*)
.settings(port in config("container") := 8080)
.settings(
organization := "com.example",
version := "0.9.0-RC1",
scalaVersion := "2.9.1",
scalacOptions := Seq("-deprecation", "-encoding", "utf8"),
resolvers ++= Dependencies.resolutionRepos,
libraryDependencies ++= Seq(
Compile.akkaActor,
Compile.sprayServer,
Test.specs2,
Container.jettyWebApp,
Container.akkaSlf4j,
Container.slf4j,
Container.logback
),
unmanagedListing
)
}
object Dependencies {
val resolutionRepos = Seq(
ScalaToolsSnapshots,
"Typesafe repo" at "http://repo.typesafe.com/typesafe/releases/",
"spray repo" at "http://repo.spray.cc/"
)
def listUnmanaged( base : RichFile ) : Keys.Classpath = {
val baseDirectories = (base / "custom-libs") +++ ( base / "custom-libs2" )
(baseDirectories ** "*.jar").classpath
}
object V {
val akka = "1.3"
val spray = "0.9.0-RC1"
val specs2 = "1.7.1"
val jetty = "8.1.0.v20120127"
val slf4j = "1.6.4"
val logback = "1.0.0"
}
object Compile {
val akkaActor = "se.scalablesolutions.akka" % "akka-actor" % V.akka % "compile"
val sprayServer = "cc.spray" % "spray-server" % V.spray % "compile"
}
object Test {
val specs2 = "org.specs2" %% "specs2" % V.specs2 % "test"
}
object Container {
val jettyWebApp = "org.eclipse.jetty" % "jetty-webapp" % V.jetty % "container"
val akkaSlf4j = "se.scalablesolutions.akka" % "akka-slf4j" % V.akka
val slf4j = "org.slf4j" % "slf4j-api" % V.slf4j
val logback = "ch.qos.logback" % "logback-classic" % V.logback
}
}
Lösung 3
Wie beantwortet von Eugene Vigdorchik, was es als folgenden Code funktioniert hat:
import sbt._
import com.github.siasia._
import PluginKeys._
import Keys._
object Build extends sbt.Build {
import Dependencies._
var unmanagedListing = unmanagedJars in Compile := {
Dependencies.listUnmanaged( file(".").getAbsoluteFile )
}
lazy val myProject = Project("spray-template", file("."))
.settings(WebPlugin.webSettings: _*)
.settings(port in config("container") := 8080)
.settings(
organization := "com.example",
version := "0.9.0-RC1",
scalaVersion := "2.9.1",
scalacOptions := Seq("-deprecation", "-encoding", "utf8"),
resolvers ++= Dependencies.resolutionRepos,
libraryDependencies ++= Seq(
C.akkaActor,
C.sprayServer,
Test.specs2,
Container.jettyWebApp,
Container.akkaSlf4j,
Container.slf4j,
Container.logback
),
unmanagedListing
)
}
object Dependencies {
val resolutionRepos = Seq(
ScalaToolsSnapshots,
"Typesafe repo" at "http://repo.typesafe.com/typesafe/releases/",
"spray repo" at "http://repo.spray.cc/"
)
def listUnmanaged( base : RichFile ) : Keys.Classpath = {
val baseDirectories = (base / "custom-libs") +++ ( base / "custom-libs2" )
(baseDirectories ** "*.jar").classpath
}
object V {
val akka = "1.3"
val spray = "0.9.0-RC1"
val specs2 = "1.7.1"
val jetty = "8.1.0.v20120127"
val slf4j = "1.6.4"
val logback = "1.0.0"
}
object C {
val akkaActor = "se.scalablesolutions.akka" % "akka-actor" % V.akka % "compile"
val sprayServer = "cc.spray" % "spray-server" % V.spray % "compile"
}
object Test {
val specs2 = "org.specs2" %% "specs2" % V.specs2 % "test"
}
object Container {
val jettyWebApp = "org.eclipse.jetty" % "jetty-webapp" % V.jetty % "container"
val akkaSlf4j = "se.scalablesolutions.akka" % "akka-slf4j" % V.akka
val slf4j = "org.slf4j" % "slf4j-api" % V.slf4j
val logback = "ch.qos.logback" % "logback-classic" % V.logback
}
}
Quellenrepo mit dem vollständigen Beispiel Erhältlich auf GitHub.
Andere Tipps
Ich poste einfach das Fragment von meinem build.sbt
Datei mit SBT 0.11.x. Es könnte wahrscheinlich ein bisschen wieder übertragen werden.
unmanagedJars in Compile <++= baseDirectory map { base =>
val libs = base / "lib"
val dirs = (libs / "batik") +++ (libs / "libtw") +++ (libs / "kiama")
(dirs ** "*.jar").classpath
}
Sie können der Liste der Ordner zusätzliche Pfade hinzufügen, um nicht verwaltete Abhängigkeiten zu scannen. Zum Beispiel in einem Ordner namens "Konfiguration" zusätzlich zu "lib" für die run
Aufgabe können Sie Folgendes hinzufügen. Für die compile
Aufgabenänderung Runtime
zu Compile
.
unmanagedClasspath in Runtime <+= (baseDirectory) map {
bd => Attributed.blank(bd / "config")
}
Hier ist eine allgemeine Lösung für die rekursive Belastung von nicht verwalteten Gläser (für SBT 0.13.x): https://stackoverflow.com/a/29357699/1348306