2011-06-26 18:27:07 +02:00
|
|
|
import sbt._
|
|
|
|
|
import Keys._
|
2012-02-20 04:41:26 +01:00
|
|
|
import java.util.regex.Pattern
|
2011-06-26 18:27:07 +02:00
|
|
|
|
|
|
|
|
object Status
|
|
|
|
|
{
|
|
|
|
|
lazy val isSnapshot = SettingKey[Boolean]("is-snapshot")
|
|
|
|
|
lazy val publishStatus = SettingKey[String]("publish-status")
|
|
|
|
|
|
|
|
|
|
def settings: Seq[Setting[_]] = Seq(
|
2012-02-20 04:41:26 +01:00
|
|
|
isSnapshot <<= version(v => v.contains("-") && !isMilestone(v)),
|
2011-06-26 18:27:07 +02:00
|
|
|
publishStatus <<= isSnapshot { snap => if(snap) "snapshots" else "releases" },
|
|
|
|
|
commands += stampVersion
|
|
|
|
|
)
|
|
|
|
|
def stampVersion = Command.command("stamp-version") { state =>
|
2011-08-05 09:46:49 +02:00
|
|
|
Project.extract(state).append((version in ThisBuild ~= stamp) :: Nil, state)
|
2011-06-26 18:27:07 +02:00
|
|
|
}
|
|
|
|
|
def stamp(v: String): String =
|
|
|
|
|
if(v endsWith Snapshot)
|
|
|
|
|
(v stripSuffix Snapshot) + "-" + timestampString(System.currentTimeMillis)
|
|
|
|
|
else
|
|
|
|
|
v
|
|
|
|
|
def timestampString(time: Long): String =
|
|
|
|
|
{
|
|
|
|
|
val format = new java.text.SimpleDateFormat("yyyyMMdd-HHmmss")
|
|
|
|
|
format.format(new java.util.Date(time))
|
|
|
|
|
}
|
|
|
|
|
final val Snapshot = "-SNAPSHOT"
|
2012-02-20 04:41:26 +01:00
|
|
|
def isMilestone(v: String) = Pattern.matches(""".+-M\d+""", v)
|
2011-06-26 18:27:07 +02:00
|
|
|
}
|