From 423ae6a252a418efd2f2cc1bc029f05bf125f6d0 Mon Sep 17 00:00:00 2001 From: gak Date: Wed, 3 Jul 2024 03:25:25 +1000 Subject: [PATCH] fix: diagnostic errors were being discarded (#1929) Fixes #1849 Error detection was far too aggressive, discarding legit schema.Errors. --- lsp/lsp.go | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/lsp/lsp.go b/lsp/lsp.go index 69d1280e64..f909a3a063 100644 --- a/lsp/lsp.go +++ b/lsp/lsp.go @@ -103,23 +103,20 @@ func (s *Server) post(err error) { // Deduplicate and associate by filename. for _, e := range ftlErrors.DeduplicateErrors(ftlErrors.UnwrapAll(err)) { - // CompilerBuildErrors are not innermost errors, so we need to check for them first. - var cbe buildengine.CompilerBuildError - if errors.As(e, &cbe) { - // CompilerBuildErrors should have emitted errors beforehand so don't alert the user again. - return - } - if !ftlErrors.Innermost(e) { continue } + var ce *schema.Error + var cbe buildengine.CompilerBuildError if errors.As(e, &ce) { filename := ce.Pos.Filename if _, exists := errByFilename[filename]; !exists { errByFilename[filename] = errSet{} } errByFilename[filename] = append(errByFilename[filename], ce) + } else if errors.As(e, &cbe) { + continue } else { errUnspecified = append(errUnspecified, err) }