sbt/project/Transform.scala

98 lines
4.5 KiB
Scala
Raw Normal View History

2011-06-26 18:27:07 +02:00
import sbt._
import Keys._
object Transform
{
2013-01-27 02:13:25 +01:00
lazy val transformSources = TaskKey[Seq[File]]("transform-sources")
lazy val inputSourceDirectories = SettingKey[Seq[File]]("input-source-directories")
lazy val inputSourceDirectory = SettingKey[File]("input-source-directory")
lazy val inputSources = TaskKey[Seq[File]]("input-sources")
lazy val sourceProperties = TaskKey[Map[String,String]]("source-properties")
2011-06-26 18:27:07 +02:00
lazy val transformResources = TaskKey[Seq[File]]("transform-resources")
lazy val inputResourceDirectories = SettingKey[Seq[File]]("input-resource-directories")
lazy val inputResourceDirectory = SettingKey[File]("input-resource-directory")
lazy val inputResources = TaskKey[Seq[File]]("input-resources")
lazy val resourceProperties = TaskKey[Map[String,String]]("resource-properties")
lazy val conscriptConfigs = TaskKey[Unit]("conscript-configs")
def conscriptSettings(launch: Reference) = Seq(
conscriptConfigs <<= (managedResources in launch in Compile, sourceDirectory in Compile).map { (res, src) =>
val source = res.filter(_.getName == "sbt.boot.properties").headOption getOrElse error("No managed boot.properties file.")
copyConscriptProperties(source, src / "conscript")
()
}
)
def copyConscriptProperties(source: File, conscriptBase: File): Seq[File] =
{
IO.delete(conscriptBase)
val pairs = Seq(
"sbt.xMain" -> "sbt",
"sbt.ScriptMain" -> "scalas",
"sbt.ConsoleMain" -> "screpl"
)
for( (main, dir) <- pairs) yield {
val file = conscriptBase / dir / "launchconfig"
copyPropertiesFile(source, main, file)
file
}
}
def copyPropertiesFile(source: File, newMain: String, target: File) {
def subMain(line: String): String = if(line.trim.startsWith("class:")) " class: " + newMain else line
IO.writeLines(target, IO.readLines(source) map subMain)
}
2013-01-27 02:13:25 +01:00
def crossGenSettings = transSourceSettings ++ seq(
sourceProperties := Map("cross.package0" -> "sbt", "cross.package1" -> "cross")
)
def transSourceSettings = seq(
inputSourceDirectory <<= sourceDirectory / "input_sources",
inputSourceDirectories <<= Seq(inputSourceDirectory).join,
inputSources <<= inputSourceDirectories.map(dirs => (dirs ** (-DirectoryFilter)).get ),
fileMappings in transformSources <<= transformSourceMappings,
transformSources <<= (fileMappings in transformSources, sourceProperties) map { (rs, props) =>
rs map { case (in, out) => transform(in, out, props) }
},
sourceGenerators <+= transformSources
)
def transformSourceMappings = (inputSources, inputSourceDirectories, sourceManaged) map { (ss, sdirs, sm) =>
(ss --- sdirs) x (rebase(sdirs, sm)|flat(sm)) toSeq
}
def configSettings = transResourceSettings ++ seq(
resourceProperties <<= (organization, version, scalaVersion, Status.isSnapshot) map { (org, v, sv, isSnapshot) =>
Map("org" -> org, "sbt.version" -> v, "scala.version" -> sv, "repositories" -> repositories(isSnapshot).mkString(IO.Newline))
}
)
def transResourceSettings = seq(
2011-06-26 18:27:07 +02:00
inputResourceDirectory <<= sourceDirectory / "input_resources",
inputResourceDirectories <<= Seq(inputResourceDirectory).join,
inputResources <<= inputResourceDirectories.map(dirs => (dirs ** (-DirectoryFilter)).get ),
2013-01-27 02:13:25 +01:00
fileMappings in transformResources <<= transformResourceMappings,
2011-06-26 18:27:07 +02:00
transformResources <<= (fileMappings in transformResources, resourceProperties) map { (rs, props) =>
rs map { case (in, out) => transform(in, out, props) }
},
2011-11-10 11:11:16 +01:00
resourceGenerators <+= transformResources
2011-06-26 18:27:07 +02:00
)
2013-01-27 02:13:25 +01:00
def transformResourceMappings = (inputResources, inputResourceDirectories, resourceManaged) map { (rs, rdirs, rm) =>
2011-06-26 18:27:07 +02:00
(rs --- rdirs) x (rebase(rdirs, rm)|flat(rm)) toSeq
}
def transform(in: File, out: File, map: Map[String, String]): File =
{
def get(key: String): String = map.getOrElse(key, error("No value defined for key '" + key + "'"))
val newString = Property.replaceAllIn(IO.read(in), mtch => get(mtch.group(1)) )
2011-06-26 19:14:17 +02:00
if(Some(newString) != read(out))
2011-06-26 18:27:07 +02:00
IO.write(out, newString)
out
}
2011-06-26 19:14:17 +02:00
def read(file: File): Option[String] = try { Some(IO.read(file)) } catch { case _: java.io.IOException => None }
2011-06-26 18:27:07 +02:00
lazy val Property = """\$\{\{([\w.-]+)\}\}""".r
def repositories(isSnapshot: Boolean) = Releases :: (if(isSnapshot) Snapshots :: Nil else Nil)
lazy val Releases = typesafeRepository("releases")
lazy val Snapshots = typesafeRepository("snapshots")
def typesafeRepository(status: String) =
""" typesafe-ivy-%s: http://repo.typesafe.com/typesafe/ivy-%<s/, [organization]/[module]/[revision]/[type]s/[artifact](-[classifier]).[ext], bootOnly""" format status
2011-11-10 11:11:16 +01:00
}