Merge pull request #4329 from gutefrage/sbt-1972

Allow same file to be packaged more than once
This commit is contained in:
eugene yokota 2018-09-12 11:52:27 -04:00 committed by GitHub
commit 07f2b43fea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 60 additions and 4 deletions

View File

@ -25,6 +25,14 @@ import sbt.util.CacheImplicits._
import sbt.util.Tracked.{ inputChanged, outputChanged }
sealed trait PackageOption
/**
* == Package ==
*
* This module provides an API to package jar files.
*
* @see [[https://docs.oracle.com/javase/tutorial/deployment/jar/index.html]]
*/
object Package {
final case class JarManifest(m: Manifest) extends PackageOption {
assert(m != null)
@ -49,11 +57,25 @@ object Package {
}
}
/**
* The jar package configuration. Contains all relevant information to create a jar file.
*
* @param sources the jar contents
* @param jar the destination jar file
* @param options additional package information, e.g. jar manifest, main class or manifest attributes
*/
final class Configuration(
val sources: Seq[(File, String)],
val jar: File,
val options: Seq[PackageOption]
)
/**
*
* @param conf the package configuration that should be build
* @param cacheStoreFactory used for jar caching. We try to avoid rebuilds as much as possible
* @param log feedback for the user
*/
def apply(conf: Configuration, cacheStoreFactory: CacheStoreFactory, log: Logger): Unit = {
val manifest = new Manifest
val main = manifest.getMainAttributes
@ -67,24 +89,30 @@ object Package {
}
setVersion(main)
type Inputs = Map[File, String] :+: FilesInfo[ModifiedFileInfo] :+: Manifest :+: HNil
type Inputs = Seq[(File, String)] :+: FilesInfo[ModifiedFileInfo] :+: Manifest :+: HNil
val cachedMakeJar = inputChanged(cacheStoreFactory make "inputs") {
(inChanged, inputs: Inputs) =>
import exists.format
val sources :+: _ :+: manifest :+: HNil = inputs
outputChanged(cacheStoreFactory make "output") { (outChanged, jar: PlainFileInfo) =>
if (inChanged || outChanged) {
makeJar(sources.toSeq, jar.file, manifest, log)
makeJar(sources, jar.file, manifest, log)
jar.file
} else
log.debug("Jar uptodate: " + jar.file)
}
}
val map = conf.sources.toMap
val inputs = map :+: lastModified(map.keySet) :+: manifest :+: HNil
val inputFiles = conf.sources.map(_._1).toSet
val inputs = conf.sources :+: lastModified(inputFiles) :+: manifest :+: HNil
cachedMakeJar(inputs)(() => exists(conf.jar))
}
/**
* updates the manifest version is there is none present.
*
* @param main the current jar attributes
*/
def setVersion(main: Attributes): Unit = {
val version = Attributes.Name.MANIFEST_VERSION
if (main.getValue(version) eq null) {

View File

@ -0,0 +1,9 @@
[@muuki88]: https://github.com/muuki88
[@gutefrageIT]: https://twitter.com/gutefrageIT
[#1972]: https://github.com/sbt/sbt/issues/1972
[#4329]: https://github.com/sbt/sbt/pull/4329
### Bug Fixes
- Enable packaging of the same file more than once [#1972][]/[#4329][] by [@muuki88][] (sponsored by [@gutefrageIT][])

View File

@ -0,0 +1,16 @@
name := "Mappings Test"
version := "0.2"
mappings in (Compile, packageBin) ++= {
val test = file("test")
Seq(
test -> "test1",
test -> "test2"
)
}
lazy val unzipPackage = taskKey[Unit]("extract jar file")
unzipPackage := {
IO.unzip((packageBin in Compile).value, target.value / "extracted")
}

View File

@ -0,0 +1,3 @@
> unzipPackage
$ exists target/extracted/test2
$ exists target/extracted/test1