48 lines
2 KiB
Text
48 lines
2 KiB
Text
![]() |
### Please describe the problem.
|
|||
|
|
|||
|
|
|||
|
### What steps will reproduce the problem?
|
|||
|
|
|||
|
Build git-annex with GHC 8.6.
|
|||
|
|
|||
|
### What version of git-annex are you using? On what operating system?
|
|||
|
|
|||
|
7.20181211, master
|
|||
|
|
|||
|
### Please provide any additional information below.
|
|||
|
|
|||
|
Following the implementation plan for the [MonadFail Proposal](https://wiki.haskell.org/MonadFail_Proposal), GHC 8.6 has enabled `-XMonadFailDesugaring` by default.
|
|||
|
|
|||
|
Some of the code in git-annex uses failable patterns in `do`-blocks, so it fails to compile starting from GHC 8.6, as there is no `MonadFail` instance for `Annex`. Here is an example of such an error:
|
|||
|
|
|||
|
Remote/Glacier.hs:165:17: error:
|
|||
|
• No instance for (Control.Monad.Fail.MonadFail Annex)
|
|||
|
arising from a do statement
|
|||
|
with the failable pattern ‘(_, Just h, _, pid)’
|
|||
|
• In a stmt of a 'do' block:
|
|||
|
(_, Just h, _, pid) <- liftIO $ createProcess cmd
|
|||
|
In the expression:
|
|||
|
do let cmd = ...
|
|||
|
(_, Just h, _, pid) <- liftIO $ createProcess cmd
|
|||
|
ok <- ifM
|
|||
|
(liftIO $ hIsEOF h)
|
|||
|
(return False, sink =<< liftIO (L.hGetContents h))
|
|||
|
liftIO $ hClose h
|
|||
|
....
|
|||
|
In an equation for ‘go’:
|
|||
|
go (Just e)
|
|||
|
= do let cmd = ...
|
|||
|
(_, Just h, _, pid) <- liftIO $ createProcess cmd
|
|||
|
ok <- ifM
|
|||
|
(liftIO $ hIsEOF h)
|
|||
|
(return False, sink =<< liftIO (L.hGetContents h))
|
|||
|
....
|
|||
|
|
|
|||
|
165 | (_, Just h, _, pid) <- liftIO $ createProcess cmd
|
|||
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|||
|
|
|||
|
|
|||
|
### Have you had any luck using git-annex before? (Sometimes we get tired of reading bug reports all day and a lil' positive end note does wonders)
|
|||
|
|
|||
|
Just trying to start using it. I have built it with `-XNoMonadFailDesugaring` for now.
|