我是Scala和SBT的新手。我注意到一个开源项目的build.sbt中有一个不熟悉的操作符:
:=
以下是一些如何使用的示例:
lazy val akkaApp = Project(id = "akka-app", base = file("akka-app"))
.settings(description := "Common Akka application stack: metrics, tracing, logging, and more.")
并且在这个更大的代码段中使用了几次:
lazy val jobServer = Project(id = "job-server", base = file("job-server"))
.settings(commonSettings)
.settings(revolverSettings)
.settings(assembly := null.asInstanceOf[File])
.settings(
description := "Spark as a Service: a RESTful job server for Apache Spark",
libraryDependencies ++= sparkDeps ++ slickDeps ++ cassandraDeps ++ securityDeps ++ coreTestDeps,
test in Test <<= (test in Test).dependsOn(packageBin in Compile in jobServerTestJar)
.dependsOn(clean in Compile in jobServerTestJar)
.dependsOn(buildPython in jobServerPython)
.dependsOn(clean in Compile in jobServerPython),
testOnly in Test <<= (testOnly in Test).dependsOn(packageBin in Compile in jobServerTestJar)
.dependsOn(clean in Compile in jobServerTestJar)
.dependsOn(buildPython in jobServerPython)
.dependsOn(clean in Compile in jobServerPython),
console in Compile <<= Defaults.consoleTask(fullClasspath in Compile, console in Compile),
fullClasspath in Compile <<= (fullClasspath in Compile).map { classpath =>
extraJarPaths ++ classpath
},
fork in Test := true
)
.settings(publishSettings)
.dependsOn(akkaApp, jobServerApi)
.disablePlugins(SbtScalariform)
我最好的猜测是,它意味着&#34;声明如果尚未宣布&#34;。
答案 0 :(得分:2)
:=
基本上与普通赋值运算符=
无关。它不是内置的scala运算符,而是一系列名为:=
的方法/宏。这些方法(或宏)是SettingKey[T]
类的成员(类似于TaskKey[T]
和InputKey[T]
)。它们使用key := value
表达式的右侧,并返回Def.Setting[T]
类型的实例(或类似地,Task
s),其中T
是所表示的值的类型靠钥匙。它们通常用中缀表示法编写。如果没有语法糖,这些方法/宏的调用将如下所示:
key.:=(value)
构造的Setting
和Task
又是构建定义的基本构建块。
这里要理解的重要一点是,左侧的键不是代码块中的某些变量。不仅仅是在函数调用的活动堆栈帧中表示内存位置(就像一个简单的变量那样),左侧的键是相当复杂的对象,可以在构建过程中检查和传递。