summaryrefslogtreecommitdiff
path: root/core/src/main
diff options
context:
space:
mode:
authorLi Haoyi <haoyi.sg@gmail.com>2017-11-25 12:34:40 -0800
committerLi Haoyi <haoyi.sg@gmail.com>2017-11-25 12:34:40 -0800
commitf98a88f898f8de10c5145a13792151663f424518 (patch)
tree4ee797baf8f268dd2772b5c2734c93e96d7871ed /core/src/main
parent2c0ecb9733dfd231c8d16b819d89d515569f104c (diff)
downloadmill-f98a88f898f8de10c5145a13792151663f424518.tar.gz
mill-f98a88f898f8de10c5145a13792151663f424518.tar.bz2
mill-f98a88f898f8de10c5145a13792151663f424518.zip
Streamline cross-build Scala syntax to avoid the unnecessary `List(...)` wrapper
Diffstat (limited to 'core/src/main')
-rw-r--r--core/src/main/scala/mill/define/Cross.scala16
-rw-r--r--core/src/main/scala/mill/discover/Discovered.scala2
2 files changed, 13 insertions, 5 deletions
diff --git a/core/src/main/scala/mill/define/Cross.scala b/core/src/main/scala/mill/define/Cross.scala
index ac1ee966..85341d12 100644
--- a/core/src/main/scala/mill/define/Cross.scala
+++ b/core/src/main/scala/mill/define/Cross.scala
@@ -9,10 +9,18 @@ case class Cross[+T](items: List[(List[Any], T)]){
def map[V](f: T => V): Cross[V] = new Cross(items.map{case (l, v) => (l, f(v))})
def withFilter(f: T => Boolean): Cross[T] = new Cross(items.filter(t => f(t._2)))
- def applyOpt(input: List[Any]): Option[T] = items.find(_._1 == input).map(_._2)
- def apply(input: List[Any]): T = applyOpt(input).getOrElse(
- throw new Exception("Unknown set of cross values: " + input + " not in known values\n" + items.map(_._1).mkString("\n"))
- )
+ def applyOpt(input: Any*): Option[T] = {
+ val inputList = input.toList
+ items.find(_._1 == inputList).map(_._2)
+ }
+ def apply(input: Any*): T = {
+ applyOpt(input:_*).getOrElse(
+ throw new Exception(
+ "Unknown set of cross values: " + input +
+ " not in known values\n" + items.map(_._1).mkString("\n")
+ )
+ )
+ }
}
object Cross{
def apply[T](t: T*) = new Cross(t.map(i => List(i) -> i).toList)
diff --git a/core/src/main/scala/mill/discover/Discovered.scala b/core/src/main/scala/mill/discover/Discovered.scala
index 36ec49b7..6bed7919 100644
--- a/core/src/main/scala/mill/discover/Discovered.scala
+++ b/core/src/main/scala/mill/discover/Discovered.scala
@@ -82,7 +82,7 @@ object Discovered {
val base = q"${TermName(c.freshName())}"
val ident = segments.reverse.zipWithIndex.foldLeft[Tree](base) {
case (prefix, (Some(name), i)) => q"$prefix.${TermName(name)}"
- case (prefix, (None, i)) => q"$prefix.apply($crossName($i))"
+ case (prefix, (None, i)) => q"$prefix.apply($crossName($i):_*)"
}
q"($base: $tpe, $crossName: List[List[Any]]) => $ident"
}