Upgrading packages/Updating to GHC 6.10: Difference between revisions
(add a summary for -fvia-C changes) |
RossPaterson (talk | contribs) (changes to Map and Set types) |
||
Line 58: | Line 58: | ||
* Changes to Arrow class definition | * Changes to Arrow class definition | ||
* Changes to Map | * Changes to types of Map and Set functions | ||
* Cabal changes | * Cabal changes | ||
* Changes to ghc-api | * Changes to ghc-api | ||
Line 91: | Line 91: | ||
And you're done. | And you're done. | ||
===Changes to types of Map and Set functions === | |||
Functions with signatures like | |||
<haskell> | |||
lookup :: (Monad m, Ord k) => k -> Map k a -> m a | |||
</haskell> | |||
have been specialized to | |||
<haskell> | |||
lookup :: (Ord k) => k -> Map k a -> Maybe a | |||
</haskell> | |||
If you use the more specific type, your code will work with both old and new versions of the <code>containers</code> package. | |||
=== Exception handling changes === | === Exception handling changes === |
Revision as of 18:19, 11 October 2008
A list of things that need updating when porting packages to newer library/cabal versions.
If you maintain a Haskell package this is for you. For older versions of this document:
Updating to GHC 6.10 and Cabal 1.6
When upgrading to GHC 6.10, any of your packages that worked against the base-3 library will continue to work. GHC 6.10 provides both the old base-3 library and the new base-4.
To ensure your old code continues to work, you can have the code compile and link against base-3, and then, over time, migrate code to the base-4 series.
Adding base-3 constraints
How to do this depends on how you build your Haskell code. We'll start with the most simplistic build mechanisms. cabal-install, the most sophisticated tool, will sort this all out for you anyway, so things should change.
ghc --make
Force use of package base-3 when using --make,
ghc --make -package base-3.0.3.0
runhaskell
If you build your packages with the 'runhaskell Setup.hs configure' method, then you can force the use of base-3,
--constraint="base<4"
cabal-install
It is worth upgrading cabal-install immediately (maybe before installing GHC). This way you can use the smart dependency solver to work out what to install for you.
* install HTTP from hackage * install zlib from hackage
Then build cabal-install.
You can also override the dependencies when using the 'cabal' binary, with
--constraint="base<4"
Typical breakages with GHC 6.10
54 new packages break with the current GHC 6.10 release candidate.
The primary reasons are:
- Changes to Arrow class definition
- Changes to types of Map and Set functions
- Cabal changes
- Changes to ghc-api
- Changes to when 'forall' is parsed
- GHC.Prim was moved,
- Changes to -fvia-C and headers
- GADT changes,
- pragma warnings tightened
- Integer constructors have moved
- New warnings and used -Werror
- Exception handling: catch, finally, throwIO don't work anymore
Each of these has a standard way to solve the problem. Techniques should be attached here.
Changes to Arrow class definition
The relevant change is essentially that Arrow became a superclass of Category. To be exact:
(>>>)
was removed from Arrow, instead we have(.)
in Categoryid
is a new function, in Category
What this means for code is that you need to declare an instance of Category as well as Arrow. A brute-force fix which should work:
- Add the following imports:
import Control.Category import Prelude hiding (id,(.)) -- conflicts with Category otherwise
- Add
instance Category [your type] where
for any Arrows - Move your
(>>>)
definition into Category, and changef >>> g = ...
intog . f = ...
- Define
id
in Category. (Actually, I'm not 100% sure if this is strictly necessary for code that used to work in 6.8, but it's safest.)
And you're done.
Changes to types of Map and Set functions
Functions with signatures like
lookup :: (Monad m, Ord k) => k -> Map k a -> m a
have been specialized to
lookup :: (Ord k) => k -> Map k a -> Maybe a
If you use the more specific type, your code will work with both old and new versions of the containers
package.
Exception handling changes
The exception system was generalised in GHC 6.10, but GHC 6.10 still provides base-3, so all your applications can continue to work.
Follow the steps for compiling against base-3 at the top of the page, baesd on your build system.
Note that if you use cabal-install, it is smart enough to work this out for you.
Changes to -fvia-C and headers
GHC 6.10 no longer includes extra header files when compiling with -fvia-C. This makes compilation with -fvia-C consistent with the native code generator.
As a consequence, defining inline functions in header files and relying on -fvia-C to pick them up no longer works.
- If you use a library that provides inline functions that you want to use, you will have to create wrapper functions to use them via FFI.
- If you use the
#def
feature of hsc2hs, you can no longer define inline functions. That is, replace#def inline void foobar() { ... }
by just#def void foobat() { ... }
Backwards compatibility
The new, suggested Cabal version range syntax,
build-depends: base-3.*
is not backwards compatible with older versions of Cabal. Users will need to upgrade to the newer Cabal to build packages that start using this syntax.