如何在 sbt 0.13 中动态获取子项目列表



如何以编程方式(以build.sbt为单位)在 sbt 0.13 中找到当前根项目的所有子项目?(我还没有尝试过Project.componentProjects,因为它是sbt 1.0中的新功能)。

lazy val root = (project in file(".") ... )
val myTask = taskKey[Unit]("some description")
myTask := {
  val masterRoot = baseDirectory.value
  // This does not work
  // val subProjects: Seq[ProjectReference] = root.aggregate
  // So I tried to specify the subproject list explicitly; still does not work
  val subProjects = Seq[Project](subPrj1)
  subProjects.foreach { subproject =>
    // All of this works if the "subproject" is hard-coded to "subPrj1"
    val subprojectTarget = target.in(subproject).value / "classes"
    val cp = (dependencyClasspath in(subproject, Compile, compile)).value
  }
}

出现以下错误:

build.sbt: error: Illegal dynamic reference: subproject
    val subprojectTarget = target.in(subproject).value / "classes"
                                     ^
build.sbt: error: Illegal dynamic reference: subproject
    val cp = (dependencyClasspath in(subproject, Compile, compile)).value

您可以通过 buildStructure.value.allProjectRefs 访问所有子项目的列表。

另一部分是你的问题是一个令人敬畏的问题,我也经常遇到。我能够通过首先创建一个List[Task[A],然后使用递归函数将其提升到Task[List[A]]来解决此类问题。

def flattenTasks[A](tasks: Seq[Def.Initialize[Task[A]]]): Def.Initialize[Task[List[A]]] =
  tasks.toList match {
    case Nil => Def.task { Nil }
    case x :: xs => Def.taskDyn {
      flattenTasks(xs) map (x.value :: _)
    }
  }
myTask := {
  val classDirectories: List[File] = Def.taskDyn {
    flattenTasks {
      for (project ← buildStructure.value.allProjectRefs)
        yield Def.task { (target in project).value / "classes" }
    }
  }.value
}

我使用了这种方法,例如在这里:实用程序方法实际使用

相关内容

  • 没有找到相关文章

最新更新