package cbt import java.io._ import java.util._ object Stage2 extends Stage2Base{ def getBuild(context: Context) = { new Lib( context.logger ).loadRoot( context ).finalBuild( context.cwd ) } def run( args: Stage2Args ): ExitCode = { import args.logger val paths = CbtPaths(args.cbtHome,args.cache) import paths._ val lib = new Lib(args.logger) logger.stage2(s"Stage2 start") val loop = args.args.lift(0) == Some("loop") val taskIndex = if (loop) { 1 } else { 0 } val task = args.args.lift( taskIndex ) val context: Context = new ContextImplementation( args.cwd, args.cwd, args.args.drop( taskIndex +1 ).toArray, logger.enabledLoggers.toArray, logger.start, args.stage2LastModified, null, args.classLoaderCache.hashMap, args.transientCache, args.cache, args.cbtHome, args.cbtHome, args.compatibilityTarget, null ) val first = lib.loadRoot( context ) val build = first.finalBuild( context.cwd ) val res = if (loop) { // TODO: this should allow looping over task specific files, like test files as well val triggerFiles = first.triggerLoopFiles.map(lib.realpath) val triggerCbtFiles = Seq( nailgun, stage1, stage2 ).map(lib.realpath _) val allTriggerFiles = triggerFiles ++ triggerCbtFiles logger.loop("Looping change detection over:\n - "++allTriggerFiles.mkString("\n - ")) lib.watch(allTriggerFiles){ case file if triggerCbtFiles.exists(file.toString startsWith _.toString) => logger.loop("Change is in CBT's own source code.") logger.loop("Restarting CBT.") scala.util.control.Breaks.break case file if triggerFiles.exists(file.toString startsWith _.toString) => val build = lib.loadRoot(context).finalBuild( context.cwd ) logger.loop(s"Re-running $task for " ++ build.show) lib.callReflective(build, task, context) } ExitCode.Success } else { val code = lib.callReflective(build, task, context) logger.stage2(s"Stage2 end") code } res } }