Skip to content

Commit

Permalink
Don't suggest -Wno-deferred-out-of-scope-variables
Browse files Browse the repository at this point in the history
Fixes #4440
  • Loading branch information
jeukshi committed Oct 29, 2024
1 parent d923d82 commit f335001
Show file tree
Hide file tree
Showing 4 changed files with 21 additions and 2 deletions.
8 changes: 6 additions & 2 deletions plugins/hls-pragmas-plugin/src/Ide/Plugin/Pragmas.hs
Original file line number Diff line number Diff line change
Expand Up @@ -126,9 +126,13 @@ suggestDisableWarning Diagnostic {_code}
pure ("Disable \"" <> w <> "\" warnings", OptGHC w)
| otherwise = []

-- Don't suggest disabling type errors as a solution to all type errors
warningBlacklist :: [T.Text]
warningBlacklist = ["deferred-type-errors"]
warningBlacklist =
-- Don't suggest disabling type errors as a solution to all type errors.
[ "deferred-type-errors"
-- Don't suggest disabling out of scope errors as a solution to all out of scope errors.
, "deferred-out-of-scope-variables"
]

-- ---------------------------------------------------------------------

Expand Down
5 changes: 5 additions & 0 deletions plugins/hls-pragmas-plugin/test/Main.hs
Original file line number Diff line number Diff line change
Expand Up @@ -114,6 +114,11 @@ codeActionTests' =
cas <- map fromAction <$> getAllCodeActions doc
liftIO $ "Disable \"deferred-type-errors\" warnings" `notElem` map (^. L.title) cas @? "Doesn't contain deferred-type-errors code action"
liftIO $ length cas == 0 @? "Expected no code actions, but got: " <> show cas
, goldenWithPragmas pragmasSuggestPlugin "doesn't suggest disabling out of scope variables" "DeferredOutOfScopeVariables" $ \doc -> do
_ <- waitForDiagnosticsFrom doc
cas <- map fromAction <$> getAllCodeActions doc
liftIO $ "Disable \"deferred-out-of-scope-variables\" warnings" `notElem` map (^. L.title) cas @? "Doesn't contain deferred-out-of-scope-variables code action"
liftIO $ length cas == 0 @? "Expected no code actions, but got: " <> show cas
]

completionTests :: TestTree
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module DeferredOutOfScopeVariables where

f :: ()
f = let x = Doesn'tExist
in undefined
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module DeferredOutOfScopeVariables where

f :: ()
f = let x = Doesn'tExist
in undefined

0 comments on commit f335001

Please sign in to comment.