warn-redundant-constraints present as errors
Alan & Kim Zimmerman
alan.zimm at gmail.com
Fri Jan 9 11:53:32 UTC 2015
In the original definingSigsNames requires the constraint, I left that out
to simplify the example, as the movement of the warning to an error still
happens.
Original definingSigsNames
------------------
-- |Find those type signatures for the specified GHC.Names.
definingSigsNames :: (SYB.Data t) =>
[GHC.Name] -- ^ The specified identifiers.
->t -- ^ A collection of declarations.
->[GHC.LSig GHC.Name] -- ^ The result.
definingSigsNames pns ds = def ds
where
def decl
= SYB.everythingStaged SYB.Renamer (++) [] ([] `SYB.mkQ` inSig) decl
where
inSig :: (GHC.LSig GHC.Name) -> [GHC.LSig GHC.Name]
inSig (GHC.L l (GHC.TypeSig ns t p))
| defines' ns /= [] = [(GHC.L l (GHC.TypeSig (defines' ns) t p))]
inSig _ = []
defines' (p::[GHC.Located GHC.Name])
= filter (\(GHC.L _ n) -> n `elem` pns) p
----------------------
On Fri, Jan 9, 2015 at 1:48 PM, Simon Peyton Jones <simonpj at microsoft.com>
wrote:
> If you remove the constraint from duplicateDecl, then I get
>
>
>
> Redundant constraint: SYB.Data t
>
> In the type signature for:
>
> definingSigsNames :: SYB.Data t =>
>
> [GHC.Name] -> t -> [GHC.LSig GHC.Name]
>
>
>
> which is 100% correct: defininingSigssNames doesn’t use its SYB.Data t
> constraint
>
>
>
> Simon
>
>
>
> *From:* Alan & Kim Zimmerman [mailto:alan.zimm at gmail.com]
> *Sent:* 09 January 2015 11:22
> *To:* Simon Peyton Jones
> *Cc:* ghc-devs at haskell.org
> *Subject:* Re: warn-redundant-constraints present as errors
>
>
>
> Thanks.
>
> I've found a case where it warns of a redundant constraint, but if I
> remove the constraint I get an error saying the constraint is required
>
> --------------------------------------------
> import qualified GHC as GHC
>
> import qualified Data.Generics as SYB
>
> duplicateDecl :: (SYB.Data t) => -- **** The constraint being warned
> against *******
> [GHC.LHsBind GHC.Name] -- ^ The declaration list
> ->t -- ^ Any signatures are in here
> ->GHC.Name -- ^ The identifier whose definition is to be
> duplicated
> ->GHC.Name -- ^ The new name (possibly qualified)
> ->IO [GHC.LHsBind GHC.Name] -- ^ The result
> duplicateDecl decls sigs n newFunName
> = do
> let sspan = undefined
> newSpan <- case typeSig of
> [] -> return sspan
> _ -> do
> let Just sspanSig = getSrcSpan typeSig
> toksSig <- getToksForSpan sspanSig
>
> let [(GHC.L sspanSig' _)] = typeSig
>
> return sspanSig'
>
> undefined
> where
> typeSig = definingSigsNames [n] sigs
>
> -- |Find those type signatures for the specified GHC.Names.
> definingSigsNames :: (SYB.Data t) =>
> [GHC.Name] -- ^ The specified identifiers.
> ->t -- ^ A collection of declarations.
> ->[GHC.LSig GHC.Name] -- ^ The result.
> definingSigsNames pns ds = def ds
> where def = undefined
>
> getSrcSpan = undefined
> getToksForSpan = undefined
>
> --------------------------------------------
>
>
>
> On Fri, Jan 9, 2015 at 1:08 PM, Simon Peyton Jones <simonpj at microsoft.com>
> wrote:
>
> I’ve fixed this
>
>
>
> *From:* Alan & Kim Zimmerman [mailto:alan.zimm at gmail.com]
> *Sent:* 08 January 2015 21:46
> *To:* ghc-devs at haskell.org; Simon Peyton Jones
> *Subject:* warn-redundant-constraints present as errors
>
>
>
> This is a great feature, here is some feedback
>
> My syntax highlighter in emacs expects warnings to have the word "warning"
> in them.
>
> So for the two warnings reported below, the first is highlighted as an
> error, and the second as a warning
>
>
> Language/Haskell/Refact/Utils/TypeUtils.hs:3036:17:
> Redundant constraint: SYB.Data t
> In the type signature for:
> duplicateDecl :: SYB.Data t =>
> [GHC.LHsBind GHC.Name]
> -> t -> GHC.Name -> GHC.Name -> RefactGhc
> [GHC.LHsBind GHC.Name]
>
> Language/Haskell/Refact/Utils/TypeUtils.hs:3045:7: Warning:
> Defined but not used: ‘toks
>
> This is in a ghci session, and the file loads without problems, so it is
> indeed a warning.
>
> Can we perhaps add the word "Warning" to the output for Redundant
> constraints?
>
> I also had a situation where it asked me to remove a whole lot of
> constraints from different functions, I did them in batches, so did not
> remove them all from the file at once, and at some point I had to add at
> least one of them back, albeit based on an error message.
>
>
>
> Regards
>
> Alan
>
>
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://www.haskell.org/pipermail/ghc-devs/attachments/20150109/c3a624c0/attachment-0001.html>
More information about the ghc-devs
mailing list