[Haskell-cafe] Local types

M Farkas-Dyck m.farkasdyck at gmail.com
Mon Jan 25 08:11:07 UTC 2016


I often wish to be able to define local types and instances, so, for example:

import Data.Set as Set

ordNubBy :: (a -> a -> Ordering) -> [a] -> [a]
ordNubBy cmp = go Set.empty
  where newtype T = T a

        instance Ord T where T x `compare` T y = cmp x y

        go _ [] = []
        go ys (x:xs) = bool (x:) id (T x ∈ ys) $ go (Set.insert (T x) ys) xs

The notion is that type and instance declarations would become legal in `let` or `where` bonds; they would effectively declare new types and instances in that scope for each use of that term; and such local types and instances could never leave the scope they were defined in, by enforcement, so consistency of instances would be preserved.

I know some related work which proposes local instances [0] but none i know proposes also local types.

I'm seeking some feedback here before i formalize further and potentially start making implements. Thoughts? Questions? Better ideas? Critical flaws?

[0] http://okmij.org/ftp/Haskell/TypeClass.html#local


More information about the Haskell-Cafe mailing list