コードのコンパイルが成功したか失敗したかをチェックし、その情報に基づいて何かを行う sbt タスクを作成しようとしています。これまでのところ、私はこれを持っています:
コンパイルが失敗すると、次のように出力されます。
[warn] Compile: Inc(Incomplete(node=Some(Task((taskDefinitionKey: ScopedKey(Scope(Select(ProjectRef(file:/Users/john-michaelreed/Downloads/NewDownloads/sbt-0.13/lesson/HelloScala1/,helloscala1)),Select(ConfigKey(compile)),Global,Global),compile)))), tpe=Error, msg=None, causes=List(Incomplete(node=Some(Task((tags: Map(Tag(compile) -> 1, Tag(cpu) -> 1), taskDefinitionKey: ScopedKey(Scope(Select(ProjectRef(file:/Users/john-michaelreed/Downloads/NewDownloads/sbt-0.13/lesson/HelloScala1/,helloscala1)),Select(ConfigKey(compile)),Global,Global),compileIncremental)))), tpe=Error, msg=None, causes=List(), directCause=Some(Compilation failed))), directCause=None)) !
文字列「コンパイルに失敗しました」が含まれています。その文字列が存在するかどうかを確認し、その結果に基づいて何かを行うことができます。
例:
val monitorTask = taskKey[Unit]("A task that gets the result of compile.")
monitorTask in Scope.GlobalScope := {
// monitorTask dependencies:
val log = streams.value.log // streams task happens-before monitorTask
val compileResult = (compile.in(Compile)).result.value // compile task happens-before monitorTask
// ---- monitorTask begins here ----
if(compileResult.toString.contains("Compilation failed")) {
log.warn("Compilation failed!")
// Do stuff
} else {
log.info("Compilation succeeded!")
// Do other stuff
}
}
しかし、それは少し壊れやすいようです。それを行うより良い方法はありますか?
ps monitorTask のテスト中に、次のバグに遭遇しました: https://github.com/sbt/sbt/issues/4444