diff options
| author | Eric Crockett <ecrockett0@gmail.com> | 2019-04-07 15:21:59 -0400 | 
|---|---|---|
| committer | Ben Gamari <ben@well-typed.com> | 2019-04-07 15:21:59 -0400 | 
| commit | 3a38ea4487173f0f8e3693a75d1c5c7d33f12f05 (patch) | |
| tree | 45cacfc3e1071d5b34820bc9562d7b024251fc56 /compiler/specialise/Specialise.hs | |
| parent | 33b0a291898b6a35d822fde59864c5c94a53d039 (diff) | |
| download | haskell-3a38ea4487173f0f8e3693a75d1c5c7d33f12f05.tar.gz | |
Fix #16282.
Previously, -W(all-)missed-specs was created with 'NoReason',
so no information about the flag was printed along with the warning.
Now, -Wall-missed-specs is listed as the Reason if it was set,
otherwise -Wmissed-specs is listed as the reason.
Diffstat (limited to 'compiler/specialise/Specialise.hs')
| -rw-r--r-- | compiler/specialise/Specialise.hs | 39 | 
1 files changed, 23 insertions, 16 deletions
| diff --git a/compiler/specialise/Specialise.hs b/compiler/specialise/Specialise.hs index c62789017f..9d87abc1ad 100644 --- a/compiler/specialise/Specialise.hs +++ b/compiler/specialise/Specialise.hs @@ -730,28 +730,35 @@ specImport dflags this_mod top_env done callers rb fn calls_for_fn         ; return (rules2 ++ rules1, final_binds) } -  |  warnMissingSpecs dflags callers -  = do { warnMsg (vcat [ hang (text "Could not specialise imported function" <+> quotes (ppr fn)) -                            2 (vcat [ text "when specialising" <+> quotes (ppr caller) -                                    | caller <- callers]) -                      , whenPprDebug (text "calls:" <+> vcat (map (pprCallInfo fn) calls_for_fn)) -                      , text "Probable fix: add INLINABLE pragma on" <+> quotes (ppr fn) ]) -       ; return ([], []) } +  | otherwise = do { tryWarnMissingSpecs dflags callers fn calls_for_fn +                   ; return ([], [])} -  | otherwise -  = return ([], [])    where      unfolding = realIdUnfolding fn   -- We want to see the unfolding even for loop breakers -warnMissingSpecs :: DynFlags -> [Id] -> Bool +-- | Returns whether or not to show a missed-spec warning. +-- If -Wall-missed-specializations is on, show the warning. +-- Otherwise, if -Wmissed-specializations is on, only show a warning +-- if there is at least one imported function being specialized, +-- and if all imported functions are marked with an inline pragma +-- Use the most specific warning as the reason. +tryWarnMissingSpecs :: DynFlags -> [Id] -> Id -> [CallInfo] -> CoreM ()  -- See Note [Warning about missed specialisations] -warnMissingSpecs dflags callers -  | wopt Opt_WarnAllMissedSpecs dflags = True -  | not (wopt Opt_WarnMissedSpecs dflags) = False -  | null callers                       = False -  | otherwise                          = all has_inline_prag callers +tryWarnMissingSpecs dflags callers fn calls_for_fn +  | wopt Opt_WarnMissedSpecs dflags +    && not (null callers) +    && allCallersInlined                  = doWarn $ Reason Opt_WarnMissedSpecs +  | wopt Opt_WarnAllMissedSpecs dflags    = doWarn $ Reason Opt_WarnAllMissedSpecs +  | otherwise                             = return ()    where -    has_inline_prag id = isAnyInlinePragma (idInlinePragma id) +    allCallersInlined = all (isAnyInlinePragma . idInlinePragma) callers +    doWarn reason =  +      warnMsg reason +        (vcat [ hang (text ("Could not specialise imported function") <+> quotes (ppr fn)) +                2 (vcat [ text "when specialising" <+> quotes (ppr caller) +                        | caller <- callers]) +          , whenPprDebug (text "calls:" <+> vcat (map (pprCallInfo fn) calls_for_fn)) +          , text "Probable fix: add INLINABLE pragma on" <+> quotes (ppr fn) ])  wantSpecImport :: DynFlags -> Unfolding -> Bool  -- See Note [Specialise imported INLINABLE things] | 
