Skip to content

Commit

Permalink
Turn strict errors off for Language Server (#10061)
Browse files Browse the repository at this point in the history
Ensure strict errors are off to prevent unrecoverable errors in IDE.
Also partially reverted a change that prevented application of changes on errors (errors are still logged, as intended).
Closes #10014.
  • Loading branch information
hubertp authored May 23, 2024
1 parent b27b5ea commit 495eed4
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -295,6 +295,7 @@ class MainModule(serverConfig: LanguageServerConfig, logLevel: Level) {
RuntimeOptions.LOG_LEVEL,
Converter.toJavaLevel(logLevel).getName
)
.option(RuntimeOptions.STRICT_ERRORS, "false")
.option(RuntimeOptions.LOG_MASKING, Masking.isMaskingEnabled.toString)
.option(RuntimeOptions.EDITION_OVERRIDE, Info.currentEdition)
.option(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -108,40 +108,48 @@ final class EnsureCompiledJob(
ctx: RuntimeContext,
logger: TruffleLogger
): Option[CompilationStatus] = {
val result = compile(module)
result match {
compile(module) match {
case Left(ex) =>
logger.log(
Level.WARNING,
s"Error while ensureCompiledModule ${module.getName}",
ex
)
Some(CompilationStatus.Failure)
case _ =>
applyEdits(new File(module.getPath)).map { changeset =>
compile(module)
.map { _ =>
// Side-effect: ensures that module's source is correctly initialized.
module.getSource()
invalidateCaches(module, changeset)
val state =
ctx.state.suggestions.getOrCreateFresh(module, module.getIr)
if (state.isIndexed) {
ctx.jobProcessor.runBackground(
AnalyzeModuleJob(module, state, module.getIr(), changeset)
)
} else {
AnalyzeModuleJob.analyzeModule(
module,
state,
module.getIr(),
changeset
)
}
runCompilationDiagnostics(module)
}
.getOrElse(CompilationStatus.Failure)
}
applyEdits(new File(module.getPath)).map { changeset =>
compile(module)
.map { _ =>
// Side-effect: ensures that module's source is correctly initialized.
module.getSource()
invalidateCaches(module, changeset)
val state =
ctx.state.suggestions.getOrCreateFresh(module, module.getIr)
if (state.isIndexed) {
ctx.jobProcessor.runBackground(
AnalyzeModuleJob(module, state, module.getIr(), changeset)
)
} else {
AnalyzeModuleJob.analyzeModule(
module,
state,
module.getIr(),
changeset
)
}
runCompilationDiagnostics(module)
}
.fold(
err => {
logger.log(
Level.WARNING,
s"Error while ensureCompiledModule ${module.getName}",
err
)
CompilationStatus.Failure
},
identity
)
}
}

Expand Down

0 comments on commit 495eed4

Please sign in to comment.