diff options
author | Jan Christopher Vogt <oss.nsp@cvogt.org> | 2016-03-18 00:14:33 -0400 |
---|---|---|
committer | Jan Christopher Vogt <oss.nsp@cvogt.org> | 2016-03-18 00:14:33 -0400 |
commit | e7131a7672dc172dc1de3078b414632d58314ee8 (patch) | |
tree | db2715a94ba7afe8876a29f4d14078f7b8bea3a1 /stage2 | |
parent | d9bc8a824d4afd937a17090be1f334a42f476cad (diff) | |
parent | cb37198374fa25e2ac1f46ccd6fe3ba98d79dd24 (diff) | |
download | cbt-e7131a7672dc172dc1de3078b414632d58314ee8.tar.gz cbt-e7131a7672dc172dc1de3078b414632d58314ee8.tar.bz2 cbt-e7131a7672dc172dc1de3078b414632d58314ee8.zip |
Merge pull request #91 from cvogt/git-dependencies
Add support for git dependencies
Diffstat (limited to 'stage2')
-rw-r--r-- | stage2/GitDependency.scala | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/stage2/GitDependency.scala b/stage2/GitDependency.scala new file mode 100644 index 0000000..c3e38b6 --- /dev/null +++ b/stage2/GitDependency.scala @@ -0,0 +1,49 @@ +package cbt +import java.io._ +import java.net._ +import scala.collection.immutable.Seq +import org.eclipse.jgit.api._ +import org.eclipse.jgit.lib.Ref + +case class GitDependency( + url: String, ref: String // example: git://github.com/cvogt/cbt.git#<some-hash> +)(implicit val logger: Logger) extends Dependency{ + override def lib = new Lib(logger) + + // TODO: add support for authentication via ssh and/or https + // See http://www.codeaffine.com/2014/12/09/jgit-authentication/ + + private val GitUrl = "(git|https)://([^/]+)/(.+)".r + private val GitUrl( _, domain, path ) = url + + private object dependenciesCache extends Cache[Seq[Dependency]] + def dependencies = dependenciesCache{ + val checkoutDirectory = paths.cbtHome ++ s"/cache/git/$domain/$path/$ref" + if(checkoutDirectory.exists){ + logger.git(s"Found existing checkout of $url#$ref in $checkoutDirectory") + } else { + + logger.git(s"Cloning $url into $checkoutDirectory") + val git = + Git.cloneRepository() + .setURI(url) + .setDirectory(checkoutDirectory) + .call() + + logger.git(s"Checking out ref $ref") + git.checkout() + .setName(ref) + .call() + + } + val managedBuild = lib.loadDynamic( + Context( cwd = checkoutDirectory, args = Seq(), logger ) + ) + Seq( managedBuild ) + } + + def exportedClasspath = ClassPath(Seq()) + def exportedJars = Seq() + private[cbt] def targetClasspath = exportedClasspath + def updated: Boolean = false +} |