Easily import all instances contained in GHC distributed libraries

Latest on Hackage:

This package is not currently in any snapshots. If you're interested in using it, we recommend adding it to Stackage Nightly. Doing so will make builds more reliable, and allow to host generated Haddocks.

BSD3 licensed by Clinton Mead
Maintained by

This package simply has a number of modules which import all the modules from each package that is distributed with GHC.

There's also a module Control.Instances.GHC_Packages, that imports all of the above modules, essentially importing every module distributed with GHC.

Why would you want to do this?

Lets say I've got a data type "D a". And a class "C".

Further, lets say I can define "C (D a)" if "a" is of class "C1". I can also "C (D a)" if "a" is of class "C2"

Lets try:

instance C1 a => C (D a) where ...

instance C2 a => C (D a) where ...

These are going to be overlapping. We can't do this.

But instead, we import Control.Instances.GHC_Packages. And then we can use reify from Template Haskell to bring every "C1" and "C2" instance in to scope that's defined anywhere in "base" or any GHC module.

We can then use Template Haskell to define all our instances. We can explicitly define what happens when both "C1" and "C2" instances are defined, perhaps prefering one over the other.

As we've got the full power of Haskell in Template Haskell, we can do these manipulations.

The package static-closure is an example of using these instances to generate it's own instances for it's data type.

This package will need to be updated with each release of GHC but currently the cabal file and modules should contain appropriate pre-processor directives that this package should work from least from GHC 7.8 to GHC 8.2.

comments powered byDisqus