Skip to content

Commit

Permalink
Don't suggest -Wno-deferred-out-of-scope-variables (haskell#4441)
Browse files Browse the repository at this point in the history
Fixes haskell#4440

Fixes test for disabling deferred-type-errors.
  • Loading branch information
jeukshi authored and soulomoon committed Nov 4, 2024
1 parent e2ab468 commit 6afd1c0
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 3 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
7 changes: 6 additions & 1 deletion plugins/hls-pragmas-plugin/test/Main.hs
Original file line number Diff line number Diff line change
Expand Up @@ -109,11 +109,16 @@ codeActionTests' =
_ -> assertFailure $ "Expected one code action, but got: " <> show cas
liftIO $ (ca ^. L.title == "Add \"NamedFieldPuns\"") @? "NamedFieldPuns code action"
executeCodeAction ca
, goldenWithPragmas pragmasSuggestPlugin "doesn't suggest disabling type errors" "DeferredTypeErrors" $ \doc -> do
, goldenWithPragmas pragmasDisableWarningPlugin "doesn't suggest disabling type errors" "DeferredTypeErrors" $ \doc -> do
_ <- waitForDiagnosticsFrom doc
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 pragmasDisableWarningPlugin "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 6afd1c0

Please sign in to comment.