From 8efe4c626700bb9f80a458ace6ec72ac6f87eeea Mon Sep 17 00:00:00 2001 From: Irmen de Jong Date: Sun, 22 Nov 2020 13:11:33 +0100 Subject: [PATCH] Fixed compiler watch to work with multiple compilation modules --- compiler/src/prog8/CompilerMain.kt | 63 +++++++++++++++--------------- docs/source/building.rst | 2 + 2 files changed, 33 insertions(+), 32 deletions(-) diff --git a/compiler/src/prog8/CompilerMain.kt b/compiler/src/prog8/CompilerMain.kt index da734cdb2..a3fcaaf56 100644 --- a/compiler/src/prog8/CompilerMain.kt +++ b/compiler/src/prog8/CompilerMain.kt @@ -55,43 +55,42 @@ private fun compileMain(args: Array) { exitProcess(1) } - // TODO: make watching work with multiple source files - - if(watchMode && moduleFiles.size<=1) { + if(watchMode) { val watchservice = FileSystems.getDefault().newWatchService() while(true) { - val filepath = pathFrom(moduleFiles.single()).normalize() - println("Continuous watch mode active. Main module: $filepath") - - try { + println("Continuous watch mode active. Modules: $moduleFiles") + val results = mutableListOf() + for(filepathRaw in moduleFiles) { + val filepath = pathFrom(filepathRaw).normalize() val compilationResult = compileProgram(filepath, !dontOptimize, !dontWriteAssembly, slowCodegenWarnings, compilationTarget, outputPath) - println("Imported files (now watching:)") - for (importedFile in compilationResult.importedFiles) { - print(" ") - println(importedFile) - val watchDir = importedFile.parent ?: Path.of(".") - watchDir.register(watchservice, StandardWatchEventKinds.ENTRY_MODIFY) - } - println("[${LocalDateTime.now().withNano(0)}] Waiting for file changes.") - - var recompile=false - while(!recompile) { - val event = watchservice.take() - for (changed in event.pollEvents()) { - val changedPath = changed.context() as Path - if(compilationResult.importedFiles.any { it.fileName == changedPath.fileName }) { - println(" change detected: $changedPath") - recompile = true - } - } - event.reset() - } - - println("\u001b[H\u001b[2J") // clear the screen - } catch (x: Exception) { - throw x + results.add(compilationResult) } + + val allImportedFiles = results.flatMap { it.importedFiles } + println("Imported files (now watching:)") + for (importedFile in allImportedFiles) { + print(" ") + println(importedFile) + val watchDir = importedFile.parent ?: Path.of(".") + watchDir.register(watchservice, StandardWatchEventKinds.ENTRY_MODIFY) + } + println("[${LocalDateTime.now().withNano(0)}] Waiting for file changes.") + + var recompile=false + while(!recompile) { + val event = watchservice.take() + for (changed in event.pollEvents()) { + val changedPath = changed.context() as Path + if(allImportedFiles.any { it.fileName == changedPath.fileName }) { + println(" change detected: $changedPath") + recompile = true + } + } + event.reset() + } + + println("\u001b[H\u001b[2J") // clear the screen } } else { diff --git a/docs/source/building.rst b/docs/source/building.rst index 79a569911..86d825b39 100644 --- a/docs/source/building.rst +++ b/docs/source/building.rst @@ -93,6 +93,8 @@ Almost instant compilation times (less than a second) can be achieved when using Start the compiler with the ``-watch`` argument to enable this. It will compile your program and then instead of exiting, it waits for any changes in the module source files. As soon as a change happens, the program gets compiled again. +It is possible to use the watch mode with multiple modules as well, but it will +recompile everything in that list even if only of the files got updated. Other options ^^^^^^^^^^^^^