You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
It took me a while to figure out that the postCopy hook is the only hook to run when you invoke 'cabal copy' and the postInstall hook is the only hook to run when you invoke 'cabal install'.
This is both confusing and unfortunate.
Since the Cabal documentation elsewhere states that 'cabal install' is just "register + copy" one would assume that upon 'cabal install' the postCopy hook runs as well.
Now I had to write two hooks, both for postCopy and for postInstall, to make it work for users that run 'cabal install' as well as cases where 'cabal copy' is used (for example by distributions, while preparing their packages).
This can probably not be fixed without breaking a bunch of Cabal packages, so maybe some kind of warning or big note in the documentation would help in the meantime.
Best regards!
Jan
The text was updated successfully, but these errors were encountered:
Yes it's pretty crazy and confusing. I'm not sure we can change it easily however as I think it would break old packages (that's why we'd not done it already).
Though perhaps someone could look at how a smooth transition might work.
Alternatively we have to wait for a full redesign of the hooks interface.
Closing as wontfix. As Duncan pointed out, we can't change the behaviour without redesigning the hooks altogether, and given the other 500 bugs on the tracker I don't think there's enough friction for anyone to ever get to this.
(Imported from Trac #718, reported by guest on 2010-07-24)
While working on the Bluetile cabal package ( http://hackage.haskell.org/package/bluetile ) I used Cabal's hook system to install executables to the libexec directory.
It took me a while to figure out that the postCopy hook is the only hook to run when you invoke 'cabal copy' and the postInstall hook is the only hook to run when you invoke 'cabal install'.
This is both confusing and unfortunate.
Since the Cabal documentation elsewhere states that 'cabal install' is just "register + copy" one would assume that upon 'cabal install' the postCopy hook runs as well.
Now I had to write two hooks, both for postCopy and for postInstall, to make it work for users that run 'cabal install' as well as cases where 'cabal copy' is used (for example by distributions, while preparing their packages).
This can probably not be fixed without breaking a bunch of Cabal packages, so maybe some kind of warning or big note in the documentation would help in the meantime.
Best regards!
Jan
The text was updated successfully, but these errors were encountered: