build.sbt中的SBT:=运算符是什么?

时间:2018-02-07 18:12:27

标签: scala sbt operators

我是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;。

1 个答案:

答案 0 :(得分:2)

:=基本上与普通赋值运算符=无关。它不是内置的scala运算符,而是一系列名为:=的方法/宏。这些方法(或宏)是SettingKey[T]类的成员(类似于TaskKey[T]InputKey[T])。它们使用key := value表达式的右侧,并返回Def.Setting[T]类型的实例(或类似地,Task s),其中T是所表示的值的类型靠钥匙。它们通常用中缀表示法编写。如果没有语法糖,这些方法/宏的调用将如下所示:

key.:=(value)

构造的SettingTask又是构建定义的基本构建块。

这里要理解的重要一点是,左侧的键不是代码块中的某些变量。不仅仅是在函数调用的活动堆栈帧中表示内存位置(就像一个简单的变量那样),左侧的键是相当复杂的对象,可以在构建过程中检查和传递。