1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332
|
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE TypeApplications #-}
{-# OPTIONS_GHC -fno-warn-orphans #-} -- instance Diagnostic {DriverMessage, GhcMessage}
module GHC.Driver.Errors.Ppr (
-- This module only exports Diagnostic instances.
) where
import GHC.Prelude
import GHC.Driver.Errors.Types
import GHC.Driver.Flags
import GHC.Driver.Session
import GHC.HsToCore.Errors.Ppr ()
import GHC.Parser.Errors.Ppr ()
import GHC.Tc.Errors.Ppr ()
import GHC.Types.Error
import GHC.Types.Error.Codes ( constructorCode )
import GHC.Unit.Types
import GHC.Utils.Outputable
import GHC.Unit.Module
import GHC.Unit.State
import GHC.Types.Hint
import GHC.Types.SrcLoc
import Data.Version
import Language.Haskell.Syntax.Decls (RuleDecl(..))
import GHC.Tc.Errors.Types (TcRnMessage)
import GHC.HsToCore.Errors.Types (DsMessage)
--
-- Suggestions
--
-- | Suggests a list of 'InstantiationSuggestion' for the '.hsig' file to the user.
suggestInstantiatedWith :: ModuleName -> GenInstantiations UnitId -> [InstantiationSuggestion]
suggestInstantiatedWith pi_mod_name insts =
[ InstantiationSuggestion k v | (k,v) <- ((pi_mod_name, mkHoleModule pi_mod_name) : insts) ]
instance Diagnostic GhcMessage where
type DiagnosticOpts GhcMessage = GhcMessageOpts
defaultDiagnosticOpts = GhcMessageOpts (defaultDiagnosticOpts @PsMessage)
(defaultDiagnosticOpts @TcRnMessage)
(defaultDiagnosticOpts @DsMessage)
(defaultDiagnosticOpts @DriverMessage)
diagnosticMessage opts = \case
GhcPsMessage m
-> diagnosticMessage (psMessageOpts opts) m
GhcTcRnMessage m
-> diagnosticMessage (tcMessageOpts opts) m
GhcDsMessage m
-> diagnosticMessage (dsMessageOpts opts) m
GhcDriverMessage m
-> diagnosticMessage (driverMessageOpts opts) m
GhcUnknownMessage (UnknownDiagnostic @e m)
-> diagnosticMessage (defaultDiagnosticOpts @e) m
diagnosticReason = \case
GhcPsMessage m
-> diagnosticReason m
GhcTcRnMessage m
-> diagnosticReason m
GhcDsMessage m
-> diagnosticReason m
GhcDriverMessage m
-> diagnosticReason m
GhcUnknownMessage m
-> diagnosticReason m
diagnosticHints = \case
GhcPsMessage m
-> diagnosticHints m
GhcTcRnMessage m
-> diagnosticHints m
GhcDsMessage m
-> diagnosticHints m
GhcDriverMessage m
-> diagnosticHints m
GhcUnknownMessage m
-> diagnosticHints m
diagnosticCode = constructorCode
instance Diagnostic DriverMessage where
type DiagnosticOpts DriverMessage = DriverMessageOpts
defaultDiagnosticOpts = DriverMessageOpts (defaultDiagnosticOpts @PsMessage)
diagnosticMessage opts = \case
DriverUnknownMessage (UnknownDiagnostic @e m)
-> diagnosticMessage (defaultDiagnosticOpts @e) m
DriverPsHeaderMessage m
-> diagnosticMessage (psDiagnosticOpts opts) m
DriverMissingHomeModules uid missing buildingCabalPackage
-> let msg | buildingCabalPackage == YesBuildingCabalPackage
= hang
(text "These modules are needed for compilation but not listed in your .cabal file's other-modules for" <+> quotes (ppr uid) <+> text ":")
4
(sep (map ppr missing))
| otherwise
=
hang
(text "Modules are not listed in options for"
<+> quotes (ppr uid) <+> text "but needed for compilation:")
4
(sep (map ppr missing))
in mkSimpleDecorated msg
DriverUnknownHiddenModules uid missing
-> let msg = hang
(text "Modules are listed as hidden in options for" <+> quotes (ppr uid) <+> text "but not part of the unit:")
4
(sep (map ppr missing))
in mkSimpleDecorated msg
DriverUnknownReexportedModules uid missing
-> let msg = hang
(text "Modules are listed as reexported in options for" <+> quotes (ppr uid) <+> text "but can't be found in any dependency:")
4
(sep (map ppr missing))
in mkSimpleDecorated msg
DriverUnusedPackages unusedArgs
-> let msg = vcat [ text "The following packages were specified" <+>
text "via -package or -package-id flags,"
, text "but were not needed for compilation:"
, nest 2 (vcat (map (withDash . displayOneUnused) unusedArgs))
]
in mkSimpleDecorated msg
where
withDash :: SDoc -> SDoc
withDash = (<+>) (text "-")
displayOneUnused (_uid, pn , v, f) =
ppr pn <> text "-" <> text (showVersion v)
<+> parens (suffix f)
suffix f = text "exposed by flag" <+> pprUnusedArg f
pprUnusedArg :: PackageArg -> SDoc
pprUnusedArg (PackageArg str) = text "-package" <+> text str
pprUnusedArg (UnitIdArg uid) = text "-package-id" <+> ppr uid
DriverUnnecessarySourceImports mod
-> mkSimpleDecorated (text "{-# SOURCE #-} unnecessary in import of " <+> quotes (ppr mod))
DriverDuplicatedModuleDeclaration mod files
-> mkSimpleDecorated $
text "module" <+> quotes (ppr mod) <+>
text "is defined in multiple files:" <+>
sep (map text files)
DriverModuleNotFound mod
-> mkSimpleDecorated (text "module" <+> quotes (ppr mod) <+> text "cannot be found locally")
DriverFileModuleNameMismatch actual expected
-> mkSimpleDecorated $
text "File name does not match module name:"
$$ text "Saw :" <+> quotes (ppr actual)
$$ text "Expected:" <+> quotes (ppr expected)
DriverUnexpectedSignature pi_mod_name _buildingCabalPackage _instantiations
-> mkSimpleDecorated $ text "Unexpected signature:" <+> quotes (ppr pi_mod_name)
DriverFileNotFound hsFilePath
-> mkSimpleDecorated (text "Can't find" <+> text hsFilePath)
DriverStaticPointersNotSupported
-> mkSimpleDecorated (text "StaticPointers is not supported in GHCi interactive expressions.")
DriverBackpackModuleNotFound modname
-> mkSimpleDecorated (text "module" <+> ppr modname <+> text "was not found")
DriverUserDefinedRuleIgnored (HsRule { rd_name = n })
-> mkSimpleDecorated $
text "Rule \"" <> ftext (unLoc n) <> text "\" ignored" $+$
text "Defining user rules is disabled under Safe Haskell"
DriverMixedSafetyImport modName
-> mkSimpleDecorated $
text "Module" <+> ppr modName <+> text ("is imported both as a safe and unsafe import!")
DriverCannotLoadInterfaceFile m
-> mkSimpleDecorated $
text "Can't load the interface file for" <+> ppr m
<> text ", to check that it can be safely imported"
DriverInferredSafeModule m
-> mkSimpleDecorated $
quotes (ppr $ moduleName m) <+> text "has been inferred as safe!"
DriverInferredSafeImport m
-> mkSimpleDecorated $
sep
[ text "Importing Safe-Inferred module "
<> ppr (moduleName m)
<> text " from explicitly Safe module"
]
DriverMarkedTrustworthyButInferredSafe m
-> mkSimpleDecorated $
quotes (ppr $ moduleName m) <+> text "is marked as Trustworthy but has been inferred as safe!"
DriverCannotImportUnsafeModule m
-> mkSimpleDecorated $
sep [ ppr (moduleName m)
<> text ": Can't be safely imported!"
, text "The module itself isn't safe." ]
DriverMissingSafeHaskellMode modName
-> mkSimpleDecorated $
ppr modName <+> text "is missing Safe Haskell mode"
DriverPackageNotTrusted state pkg
-> mkSimpleDecorated $
pprWithUnitState state
$ text "The package ("
<> ppr pkg
<> text ") is required to be trusted but it isn't!"
DriverCannotImportFromUntrustedPackage state m
-> mkSimpleDecorated $
sep [ ppr (moduleName m)
<> text ": Can't be safely imported!"
, text "The package ("
<> (pprWithUnitState state $ ppr (moduleUnit m))
<> text ") the module resides in isn't trusted."
]
DriverRedirectedNoMain mod_name
-> mkSimpleDecorated $ (text
("Output was redirected with -o, " ++
"but no output will be generated.") $$
(text "There is no module named" <+>
quotes (ppr mod_name) <> text "."))
DriverHomePackagesNotClosed needed_unit_ids
-> mkSimpleDecorated $ vcat ([text "Home units are not closed."
, text "It is necessary to also load the following units:" ]
++ map (\uid -> text "-" <+> ppr uid) needed_unit_ids)
diagnosticReason = \case
DriverUnknownMessage m
-> diagnosticReason m
DriverPsHeaderMessage {}
-> ErrorWithoutFlag
DriverMissingHomeModules{}
-> WarningWithFlag Opt_WarnMissingHomeModules
DriverUnknownHiddenModules {}
-> ErrorWithoutFlag
DriverUnknownReexportedModules {}
-> ErrorWithoutFlag
DriverUnusedPackages{}
-> WarningWithFlag Opt_WarnUnusedPackages
DriverUnnecessarySourceImports{}
-> WarningWithFlag Opt_WarnUnusedImports
DriverDuplicatedModuleDeclaration{}
-> ErrorWithoutFlag
DriverModuleNotFound{}
-> ErrorWithoutFlag
DriverFileModuleNameMismatch{}
-> ErrorWithoutFlag
DriverUnexpectedSignature{}
-> ErrorWithoutFlag
DriverFileNotFound{}
-> ErrorWithoutFlag
DriverStaticPointersNotSupported
-> WarningWithoutFlag
DriverBackpackModuleNotFound{}
-> ErrorWithoutFlag
DriverUserDefinedRuleIgnored{}
-> WarningWithoutFlag
DriverMixedSafetyImport{}
-> ErrorWithoutFlag
DriverCannotLoadInterfaceFile{}
-> ErrorWithoutFlag
DriverInferredSafeModule{}
-> WarningWithFlag Opt_WarnSafe
DriverMarkedTrustworthyButInferredSafe{}
->WarningWithFlag Opt_WarnTrustworthySafe
DriverInferredSafeImport{}
-> WarningWithFlag Opt_WarnInferredSafeImports
DriverCannotImportUnsafeModule{}
-> ErrorWithoutFlag
DriverMissingSafeHaskellMode{}
-> WarningWithFlag Opt_WarnMissingSafeHaskellMode
DriverPackageNotTrusted{}
-> ErrorWithoutFlag
DriverCannotImportFromUntrustedPackage{}
-> ErrorWithoutFlag
DriverRedirectedNoMain {}
-> ErrorWithoutFlag
DriverHomePackagesNotClosed {}
-> ErrorWithoutFlag
diagnosticHints = \case
DriverUnknownMessage m
-> diagnosticHints m
DriverPsHeaderMessage psMsg
-> diagnosticHints psMsg
DriverMissingHomeModules{}
-> noHints
DriverUnknownHiddenModules {}
-> noHints
DriverUnknownReexportedModules {}
-> noHints
DriverUnusedPackages{}
-> noHints
DriverUnnecessarySourceImports{}
-> noHints
DriverDuplicatedModuleDeclaration{}
-> noHints
DriverModuleNotFound{}
-> noHints
DriverFileModuleNameMismatch{}
-> noHints
DriverUnexpectedSignature pi_mod_name buildingCabalPackage instantiations
-> if buildingCabalPackage == YesBuildingCabalPackage
then [SuggestAddSignatureCabalFile pi_mod_name]
else [SuggestSignatureInstantiations pi_mod_name (suggestInstantiatedWith pi_mod_name instantiations)]
DriverFileNotFound{}
-> noHints
DriverStaticPointersNotSupported
-> noHints
DriverBackpackModuleNotFound{}
-> noHints
DriverUserDefinedRuleIgnored{}
-> noHints
DriverMixedSafetyImport{}
-> noHints
DriverCannotLoadInterfaceFile{}
-> noHints
DriverInferredSafeModule{}
-> noHints
DriverInferredSafeImport{}
-> noHints
DriverCannotImportUnsafeModule{}
-> noHints
DriverMissingSafeHaskellMode{}
-> noHints
DriverPackageNotTrusted{}
-> noHints
DriverMarkedTrustworthyButInferredSafe{}
-> noHints
DriverCannotImportFromUntrustedPackage{}
-> noHints
DriverRedirectedNoMain {}
-> noHints
DriverHomePackagesNotClosed {}
-> noHints
diagnosticCode = constructorCode
|