@@ -21,10 +21,12 @@ lazy val sbtPluginFilePath: String =
2121def log (msg : String ) = println(Console .GREEN + msg + Console .RESET )
2222
2323/** Executes shell command, returns false in case of error. */
24- def exec (projectDir : Path , binary : String , arguments : String * ): Int =
24+ def exec (projectDir : Path , binary : String , arguments : Seq [String ], environment : Map [String , String ]): Int =
25+ import collection .JavaConverters ._
2526 val command = binary +: arguments
2627 log(command.mkString(" " ))
2728 val builder = new ProcessBuilder (command : _* ).directory(projectDir.toFile).inheritIO()
29+ builder.environment.putAll(environment.asJava)
2830 val process = builder.start()
2931 val exitCode = process.waitFor()
3032 exitCode
@@ -40,6 +42,7 @@ sealed trait CommunityProject:
4042 val dependencies : List [CommunityProject ]
4143 val binaryName : String
4244 val runCommandsArgs : List [String ] = Nil
45+ val environment : Map [String , String ] = Map .empty
4346
4447 final val projectDir = communitybuildDir.resolve(" community-projects" ).resolve(project)
4548
@@ -53,7 +56,7 @@ sealed trait CommunityProject:
5356 log(s " Publishing $project" )
5457 if publishCommand eq null then
5558 throw RuntimeException (s " Publish command is not specified for $project. Project details: \n $this" )
56- val exitCode = exec(projectDir, binaryName, (runCommandsArgs :+ publishCommand): _* )
59+ val exitCode = exec(projectDir, binaryName, (runCommandsArgs :+ publishCommand), environment )
5760 if exitCode != 0 then
5861 throw RuntimeException (s " Publish command exited with code $exitCode for project $project. Project details: \n $this" )
5962 published = true
@@ -63,11 +66,11 @@ sealed trait CommunityProject:
6366 log(s " Documenting $project" )
6467 if docCommand eq null then
6568 throw RuntimeException (s " Doc command is not specified for $project. Project details: \n $this" )
66- val exitCode = exec(projectDir, binaryName, (runCommandsArgs :+ docCommand): _* )
69+ val exitCode = exec(projectDir, binaryName, (runCommandsArgs :+ docCommand), environment )
6770 if exitCode != 0 then
6871 throw RuntimeException (s " Doc command exited with code $exitCode for project $project. Project details: \n $this" )
6972
70- final def build (): Int = exec(projectDir, binaryName, buildCommands : _* )
73+ final def build (): Int = exec(projectDir, binaryName, buildCommands, environment )
7174
7275 final def buildCommands = runCommandsArgs :+ testCommand
7376
@@ -86,6 +89,7 @@ final case class MillCommunityProject(
8689 // uncomment once mill is released
8790 // if ignoreDocs then null else s"$baseCommand.docJar"
8891 override val runCommandsArgs = List (" -i" , " -D" , s " dottyVersion= $compilerVersion" )
92+ override val environment = Map (" MILL_VERSION" -> " 0.9.6-16-a5da34" )
8993
9094final case class SbtCommunityProject (
9195 project : String ,
@@ -102,12 +106,12 @@ final case class SbtCommunityProject(
102106 scalacOptions.map(" \" " + _ + " \" " ).mkString(" List(" , " ," , " )" )
103107
104108 private val baseCommand =
105- " clean; set logLevel in Global := Level.Error; set updateOptions in Global ~= (_.withLatestSnapshots(false)); "
106- ++ (if scalacOptions.isEmpty then " " else s """ set scalacOptions in Global ++= $scalacOptionsString; """ )
109+ " clean; set Global/ logLevel := Level.Error; set Global/updateOptions ~= (_.withLatestSnapshots(false)); "
110+ ++ (if scalacOptions.isEmpty then " " else s """ set Global/scalacOptions ++= $scalacOptionsString; """ )
107111 ++ s " ++ $compilerVersion!; "
108112
109113 override val testCommand =
110- """ set testOptions in Global += Tests.Argument(TestFramework("munit.Framework"), "+l"); """
114+ """ set Global/testOptions += Tests.Argument(TestFramework("munit.Framework"), "+l"); """
111115 ++ s " $baseCommand$sbtTestCommand"
112116
113117 override val publishCommand =
@@ -124,7 +128,7 @@ final case class SbtCommunityProject(
124128 case Some (ivyHome) => List (s " -Dsbt.ivy.home= $ivyHome" )
125129 case _ => Nil
126130 extraSbtArgs ++ sbtProps ++ List (
127- " -sbt-version" , " 1.4.9 " ,
131+ " -sbt-version" , " 1.5.0 " ,
128132 " -Dsbt.supershell=false" ,
129133 s " -Ddotty.communitybuild.dir= $communitybuildDir" ,
130134 s " --addPluginSbtFile= $sbtPluginFilePath"
@@ -140,12 +144,12 @@ object projects:
140144
141145 private def forceDoc (projects : String * ) =
142146 projects.map(project =>
143- s """ ;set $project/Compile/doc/sources ++= ( $project/Compile/doc/tastyFiles).value ; $project/doc """
147+ s """ ;set $project/Compile/doc/sources ++= ( $project/Compile/doc/dotty.tools.sbtplugin.DottyPlugin.autoImport. tastyFiles).value ; $project/doc """
144148 ).mkString(" " )
145149
146150 private def aggregateDoc (in : String )(projects : String * ) =
147151 val tastyFiles =
148- (in +: projects).map(p => s " ( $p/Compile/doc/tastyFiles).value " ).mkString(" ++ " )
152+ (in +: projects).map(p => s " ( $p/Compile/doc/dotty.tools.sbtplugin.DottyPlugin.autoImport. tastyFiles).value " ).mkString(" ++ " )
149153 s """ ;set $in/Compile/doc/sources ++= file("a.scala") +: ( $tastyFiles) ; $in/doc """
150154
151155 lazy val utest = MillCommunityProject (
@@ -512,7 +516,7 @@ object projects:
512516
513517 lazy val cats = SbtCommunityProject (
514518 project = " cats" ,
515- sbtTestCommand = " set scalaJSStage in Global := FastOptStage;buildJVM;validateAllJS" ,
519+ sbtTestCommand = " set Global/scalaJSStage := FastOptStage;buildJVM;validateAllJS" ,
516520 sbtPublishCommand = " catsJVM/publishLocal;catsJS/publishLocal" ,
517521 dependencies = List (discipline, disciplineMunit, scalacheck, simulacrumScalafixAnnotations),
518522 scalacOptions = SbtCommunityProject .scalacOptions.filter(_ != " -Ysafe-init" ) // disable -Ysafe-init, due to -Xfatal-warning
0 commit comments