[GHC] #12772: (type f1 ~> f2 = forall a. f1 a -> f2 a) to core libraries
GHC
ghc-devs at haskell.org
Thu Oct 27 23:54:23 UTC 2016
#12772: (type f1 ~> f2 = forall a. f1 a -> f2 a) to core libraries
-------------------------------------+-------------------------------------
Reporter: Iceland_jack | Owner:
Type: feature request | Status: new
Priority: normal | Milestone:
Component: Build System | Version: 8.0.1
Resolution: | Keywords:
Operating System: Unknown/Multiple | Architecture:
| Unknown/Multiple
Type of failure: None/Unknown | Test Case:
Blocked By: | Blocking:
Related Tickets: | Differential Rev(s):
Wiki Page: |
-------------------------------------+-------------------------------------
Description changed by Iceland_jack:
@@ -12,14 +12,44 @@
- unLift :: Applicative f
- => Lift f a -> f a
- mapLift :: (f a -> g a)
- -> Lift f a -> Lift g a
- mapFreeT :: (Functor f, Functor m)
- => (forall a. m a -> m' a)
- -> FreeT f m a -> FreeT f m' a
- vmap :: (a -> a')
- -> Vec a n -> Vec a' n
- liftIO :: MonadIO m
- => IO a -> m a
- hoist :: Monad m
- => (forall a. m a -> n a)
- -> t m b -> t n b
+ unLift :: Applicative f
+ => Lift f a -> f a
+ mapLift :: (f a -> g a)
+ -> Lift f a -> Lift g a
+ mapFreeT :: (Functor f, Functor m)
+ => (forall a. m a -> m' a)
+ -> FreeT f m a -> FreeT f m' a
+ vmap :: (a -> a')
+ -> Vec a n -> Vec a' n
+ liftIO :: MonadIO m
+ => IO a -> m a
+ hoist :: Monad m
+ => (forall a. m a -> n a)
+ -> t m b -> t n b
+ trans :: (Monad m, Monad m')
+ => (forall a. m a -> m' a)
+ -> Bundle m v a -> Bundle m' v a
+ process :: Monad m
+ => (forall a. k a -> i -> a)
+ -> MachineT m k o -> ProcessT m i o
+ runAlt :: Alternative g
+ => (forall x. f x -> g x)
+ -> Alt f a -> g a
+ hoistAlt :: (forall a. f a -> g a)
+ -> Alt f b -> Alt g b
+ fromCurried :: Functor f
+ => (forall a. k a -> Curried f h a)
+ -> Day f k b -> h b
+ hoistScope :: Functor f
+ => (forall x. f x -> g x)
+ -> Scope b f a -> Scope b g a
+
+ haddockWithGhc :: (forall a. [Flag] -> Ghc a -> IO a) -> [String] -> IO ()
+
+ newtype Alt f a = Alt { _runAlt :: forall g. Alternative g => (forall x. f
+ x -> g x) -> g a }
+
+ newtype Builder = Builder (forall r. BuildStep r -> BuildStep r)
+
+ data Zipper t a = Zipper (forall b. Seq b -> t b) {-# UNPACK #-} !Int
+ !(Seq a)
+
+ class MonadCatch m => MonadMask m where
+ mask :: ((forall a. m a -> m a) -> m b) -> m b
@@ -31,14 +61,43 @@
- unLift :: Applicative f
- => Lift f ~> f
- mapLift :: f ~> g
- -> Lift f ~> Lift g
- mapFreeT :: (Functor f, Functor m)
- => m ~> m'
- -> FreeT f m ~> FreeT f m'
- vmap :: (a -> a')
- -> Vec a ~> Vec a'
- liftIO :: MonadIO m
- => IO ~> m
- hoist :: Monad m
- => m ~> n
- -> t m ~> t n
+ unLift :: Applicative f
+ => Lift f ~> f
+ mapLift :: f ~> g
+ -> Lift f ~> Lift g
+ mapFreeT :: (Functor f, Functor m)
+ => m ~> m'
+ -> FreeT f m ~> FreeT f m'
+ vmap :: (a -> a')
+ -> Vec a ~> Vec a'
+ liftIO :: MonadIO m
+ => IO ~> m
+ hoist :: Monad m
+ => m ~> n
+ -> t m ~> t n
+ trans :: (Monad m, Monad m')
+ => m ~> m'
+ -> Bundle m v ~> Bundle m' v
+ process :: Monad m
+ => k ~> (i -> )
+ -> MachineT m k ~> ProcessT m i
+ runAlt :: Alternative g
+ => f ~> g
+ -> Alt f ~> g
+ hoistAlt :: f ~> g
+ -> Alt f ~> Alt g
+ fromCurried :: Functor f
+ => (k ~> Curried f h)
+ -> Day f k ~> h
+ hoistScope :: Functor f
+ => f ~> g
+ -> Scope b f ~> Scope b g
+
+ haddockWithGhc :: ([Flag] -> Ghc ~> IO) -> [String] -> IO ()
+
+ newtype Alt f a = Alt { _runAlt :: forall g. Alternative g => (f ~> g) ->
+ g a }
+
+ newtype Builder = Builder (BuildStep ~> BuildStep)
+
+ data Zipper t a = Zipper (Seq ~> t) {-# UNPACK #-} !Int !(Seq a)
+
+ class MonadCatch m => MonadMask m where
+ mask :: ((m ~> m) -> m b) -> m b
@@ -46,0 +105,51 @@
+
+ these examples are pretty similar.
+
+ ----
+
+ Same for
+
+ {{{#!hs
+ mapBlock :: (forall e x. n e x -> n' e x)
+ -> Block n e x -> Block n' e x
+ mapGraph :: (forall e x. n e x -> n' e x)
+ -> Graph n e x -> Graph n' e x
+ mapGraphNodes1 :: (forall e x. CmmNode e x -> CmmNode e x)
+ -> CmmGraph -> CmmGraph
+ foldCat :: (Catenated t, Category s)
+ => (forall a b. r a b -> s a b)
+ -> t r a b -> s a b
+ mapCat :: Catenated t
+ => (forall a b. r a b -> s a b)
+ -> t r a b -> t s a b
+
+ newtype Copastro p a b = Copastro { runCopastro :: forall r. Costrong r =>
+ (forall x y. p x y -> r x y) -> r a b }
+ newtype CopastroSum p a b = CopastroSum { runCopastroSum :: forall r.
+ Cochoice r => (forall x y. p x y -> r x y) -> r a b }
+ }}}
+
+ vs
+
+ {{{#!hs
+ type f1 ~~> f2 = forall a b. f1 a b -> f2 a b
+
+ mapBlock :: n ~~> n'
+ -> Block n ~~> Block n'
+ mapGraph :: n ~~> n'
+ -> Graph n ~~> Graph n'
+ mapGraphNodes1 :: CmmNode ~~> CmmNode
+ -> CmmGraph -> CmmGraph
+ foldCat :: (Catenated t, Category s)
+ => r ~~> s
+ -> t r ~~> s
+ mapCat :: Catenated t
+ => r ~~> s
+ -> t r ~~> t s
+
+
+ newtype Copastro p a b = Copastro { runCopastro :: forall r. Costrong r =>
+ (p ~~> r) -> r a b }
+ newtype CopastroSum p a b = CopastroSum { runCopastroSum :: forall r.
+ Cochoice r => (p ~~> r) -> r a b }
+ }}}
New description:
Is this something that belongs to core libraries (it has other names in
the wild, `:~>`, `Natural`..)
{{{#!hs
type f1 ~> f2 = forall a. f1 a -> f2 a
}}}
I use it all the time and end up redefining it (it is such a short type
that maybe it's not worth it)
{{{#!hs
unLift :: Applicative f
=> Lift f a -> f a
mapLift :: (f a -> g a)
-> Lift f a -> Lift g a
mapFreeT :: (Functor f, Functor m)
=> (forall a. m a -> m' a)
-> FreeT f m a -> FreeT f m' a
vmap :: (a -> a')
-> Vec a n -> Vec a' n
liftIO :: MonadIO m
=> IO a -> m a
hoist :: Monad m
=> (forall a. m a -> n a)
-> t m b -> t n b
trans :: (Monad m, Monad m')
=> (forall a. m a -> m' a)
-> Bundle m v a -> Bundle m' v a
process :: Monad m
=> (forall a. k a -> i -> a)
-> MachineT m k o -> ProcessT m i o
runAlt :: Alternative g
=> (forall x. f x -> g x)
-> Alt f a -> g a
hoistAlt :: (forall a. f a -> g a)
-> Alt f b -> Alt g b
fromCurried :: Functor f
=> (forall a. k a -> Curried f h a)
-> Day f k b -> h b
hoistScope :: Functor f
=> (forall x. f x -> g x)
-> Scope b f a -> Scope b g a
haddockWithGhc :: (forall a. [Flag] -> Ghc a -> IO a) -> [String] -> IO ()
newtype Alt f a = Alt { _runAlt :: forall g. Alternative g => (forall x. f
x -> g x) -> g a }
newtype Builder = Builder (forall r. BuildStep r -> BuildStep r)
data Zipper t a = Zipper (forall b. Seq b -> t b) {-# UNPACK #-} !Int
!(Seq a)
class MonadCatch m => MonadMask m where
mask :: ((forall a. m a -> m a) -> m b) -> m b
}}}
becomes
{{{#!hs
unLift :: Applicative f
=> Lift f ~> f
mapLift :: f ~> g
-> Lift f ~> Lift g
mapFreeT :: (Functor f, Functor m)
=> m ~> m'
-> FreeT f m ~> FreeT f m'
vmap :: (a -> a')
-> Vec a ~> Vec a'
liftIO :: MonadIO m
=> IO ~> m
hoist :: Monad m
=> m ~> n
-> t m ~> t n
trans :: (Monad m, Monad m')
=> m ~> m'
-> Bundle m v ~> Bundle m' v
process :: Monad m
=> k ~> (i -> )
-> MachineT m k ~> ProcessT m i
runAlt :: Alternative g
=> f ~> g
-> Alt f ~> g
hoistAlt :: f ~> g
-> Alt f ~> Alt g
fromCurried :: Functor f
=> (k ~> Curried f h)
-> Day f k ~> h
hoistScope :: Functor f
=> f ~> g
-> Scope b f ~> Scope b g
haddockWithGhc :: ([Flag] -> Ghc ~> IO) -> [String] -> IO ()
newtype Alt f a = Alt { _runAlt :: forall g. Alternative g => (f ~> g) ->
g a }
newtype Builder = Builder (BuildStep ~> BuildStep)
data Zipper t a = Zipper (Seq ~> t) {-# UNPACK #-} !Int !(Seq a)
class MonadCatch m => MonadMask m where
mask :: ((m ~> m) -> m b) -> m b
}}}
these examples are pretty similar.
----
Same for
{{{#!hs
mapBlock :: (forall e x. n e x -> n' e x)
-> Block n e x -> Block n' e x
mapGraph :: (forall e x. n e x -> n' e x)
-> Graph n e x -> Graph n' e x
mapGraphNodes1 :: (forall e x. CmmNode e x -> CmmNode e x)
-> CmmGraph -> CmmGraph
foldCat :: (Catenated t, Category s)
=> (forall a b. r a b -> s a b)
-> t r a b -> s a b
mapCat :: Catenated t
=> (forall a b. r a b -> s a b)
-> t r a b -> t s a b
newtype Copastro p a b = Copastro { runCopastro :: forall r. Costrong r =>
(forall x y. p x y -> r x y) -> r a b }
newtype CopastroSum p a b = CopastroSum { runCopastroSum :: forall r.
Cochoice r => (forall x y. p x y -> r x y) -> r a b }
}}}
vs
{{{#!hs
type f1 ~~> f2 = forall a b. f1 a b -> f2 a b
mapBlock :: n ~~> n'
-> Block n ~~> Block n'
mapGraph :: n ~~> n'
-> Graph n ~~> Graph n'
mapGraphNodes1 :: CmmNode ~~> CmmNode
-> CmmGraph -> CmmGraph
foldCat :: (Catenated t, Category s)
=> r ~~> s
-> t r ~~> s
mapCat :: Catenated t
=> r ~~> s
-> t r ~~> t s
newtype Copastro p a b = Copastro { runCopastro :: forall r. Costrong r =>
(p ~~> r) -> r a b }
newtype CopastroSum p a b = CopastroSum { runCopastroSum :: forall r.
Cochoice r => (p ~~> r) -> r a b }
}}}
--
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/12772#comment:3>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list