From 3dadfbdf338af0e72eefada7bbcb997b62a3798e Mon Sep 17 00:00:00 2001 From: Li Haoyi Date: Mon, 13 Aug 2018 01:22:04 +0800 Subject: cleanup root dir --- ci/version.sc | 37 +++++++++++++++++++++++++++++++++++++ 1 file changed, 37 insertions(+) create mode 100644 ci/version.sc (limited to 'ci/version.sc') diff --git a/ci/version.sc b/ci/version.sc new file mode 100644 index 0000000..4e73530 --- /dev/null +++ b/ci/version.sc @@ -0,0 +1,37 @@ +import ammonite.ops.{%%, pwd} + +val isMasterCommit = { + sys.env.get("TRAVIS_PULL_REQUEST") == Some("false") && + (sys.env.get("TRAVIS_BRANCH") == Some("master") || sys.env("TRAVIS_TAG") != "") +} + +def gitHead = + sys.env.get("TRAVIS_COMMIT").getOrElse( + %%('git, "rev-parse", "HEAD")(pwd).out.string.trim() + ) + + + +def publishVersion = { + val tag = + try Option( + %%('git, 'describe, "--exact-match", "--tags", "--always", gitHead)(pwd).out.string.trim() + ) + catch{case e => None} + + val dirtySuffix = %%('git, 'diff)(pwd).out.string.trim() match{ + case "" => "" + case s => "-DIRTY" + Integer.toHexString(s.hashCode) + } + + tag match{ + case Some(t) => (t, t) + case None => + val latestTaggedVersion = %%('git, 'describe, "--abbrev=0", "--always", "--tags")(pwd).out.trim + + val commitsSinceLastTag = + %%('git, "rev-list", gitHead, "--not", latestTaggedVersion, "--count")(pwd).out.trim.toInt + + (latestTaggedVersion, s"$latestTaggedVersion-$commitsSinceLastTag-${gitHead.take(6)}$dirtySuffix") + } +} -- cgit v1.2.3