package sbt
import Types.const
import java.io.File
sealed abstract class AddSettings
object AddSettings {
private[sbt] final class Sequence(val sequence: Seq[AddSettings]) extends AddSettings
private[sbt] final object User extends AddSettings
private[sbt] final class Plugins(val include: Plugin => Boolean) extends AddSettings
private[sbt] final class AutoPlugins(val include: AutoPlugin => Boolean) extends AddSettings
private[sbt] final class DefaultSbtFiles(val include: File => Boolean) extends AddSettings
private[sbt] final class SbtFiles(val files: Seq[File]) extends AddSettings
private[sbt] final object BuildScalaFiles extends AddSettings
val autoPlugins: AddSettings = new AutoPlugins(const(true))
val buildScalaFiles: AddSettings = BuildScalaFiles
val nonAutoPlugins: AddSettings = plugins(const(true))
val allPlugins: AddSettings = seq(autoPlugins, nonAutoPlugins)
def plugins(include: Plugin => Boolean): AddSettings = new Plugins(include)
val userSettings: AddSettings = User
val defaultSbtFiles: AddSettings = new DefaultSbtFiles(const(true))
def sbtFiles(files: File*): AddSettings = new SbtFiles(files)
def seq(autos: AddSettings*): AddSettings = new Sequence(autos)
val allDefaults: AddSettings = seq(autoPlugins, buildScalaFiles, userSettings, nonAutoPlugins, defaultSbtFiles)
def append(a: AddSettings, b: AddSettings): AddSettings = (a, b) match {
case (sa: Sequence, sb: Sequence) => seq(sa.sequence ++ sb.sequence: _*)
case (sa: Sequence, _) => seq(sa.sequence :+ b: _*)
case (_, sb: Sequence) => seq(a +: sb.sequence: _*)
case _ => seq(a, b)
}
def clearSbtFiles(a: AddSettings): AddSettings = tx(a) {
case _: DefaultSbtFiles | _: SbtFiles => None
case x => Some(x)
} getOrElse seq()
private[sbt] def tx(a: AddSettings)(f: AddSettings => Option[AddSettings]): Option[AddSettings] = a match {
case s: Sequence =>
s.sequence.flatMap { b => tx(b)(f) } match {
case Seq() => None
case Seq(x) => Some(x)
case ss => Some(new Sequence(ss))
}
case x => f(x)
}
}