diff options
| author | Alec Theriault <alec.theriault@gmail.com> | 2019-05-17 11:23:40 -0400 | 
|---|---|---|
| committer | Alec Theriault <alec.theriault@gmail.com> | 2019-05-17 08:51:27 -0700 | 
| commit | 384577e862171bdedc9311c9d17f7ad3a4a33456 (patch) | |
| tree | 0807cd0e9eafc51f382c987a9c921bf219cdb712 /haddock-api | |
| parent | b4c2b90dc5c19eb5ca1420d37d1fc1b0ed184afd (diff) | |
Fix #1063 with better parenthesization logic for contexts
The only other change in html/hoogle/hyperlinker output for the boot
libraries that this caused is a fix to some Hoogle output for implicit
params.
```
$ diff -r _build/docs/ old_docs
diff -r _build/docs/html/libraries/base/base.txt old_docs/html/libraries/base/base.txt
13296c13296
< assertError :: (?callStack :: CallStack) => Bool -> a -> a
---
> assertError :: ?callStack :: CallStack => Bool -> a -> a
```
Diffstat (limited to 'haddock-api')
| -rw-r--r-- | haddock-api/src/Haddock/GhcUtils.hs | 6 | 
1 files changed, 4 insertions, 2 deletions
| diff --git a/haddock-api/src/Haddock/GhcUtils.hs b/haddock-api/src/Haddock/GhcUtils.hs index 29a52faf..5cc005cc 100644 --- a/haddock-api/src/Haddock/GhcUtils.hs +++ b/haddock-api/src/Haddock/GhcUtils.hs @@ -275,11 +275,13 @@ reparenTypePrec = go    go p (HsKindSig x ty kind)      = paren p PREC_SIG $ HsKindSig x (goL PREC_SIG ty) (goL PREC_SIG kind)    go p (HsIParamTy x n ty) -    = paren p PREC_CTX $ HsIParamTy x n (reparenLType ty) +    = paren p PREC_SIG $ HsIParamTy x n (reparenLType ty)    go p (HsForAllTy x tvs ty)      = paren p PREC_CTX $ HsForAllTy x (map (fmap reparenTyVar) tvs) (reparenLType ty)    go p (HsQualTy x ctxt ty) -    = paren p PREC_FUN $ HsQualTy x (fmap (map reparenLType) ctxt) (reparenLType ty) +    = let p' [_] = PREC_CTX +          p' _   = PREC_TOP -- parens will get added anyways later... +      in paren p PREC_CTX $ HsQualTy x (fmap (\xs -> map (goL (p' xs)) xs) ctxt) (goL PREC_TOP ty)    go p (HsFunTy x ty1 ty2)      = paren p PREC_FUN $ HsFunTy x (goL PREC_FUN ty1) (goL PREC_TOP ty2)    go p (HsAppTy x fun_ty arg_ty) | 
