<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; "><div>A wiki page is desperately needed about this. One which I'll have to create after the POPL deadline (July 10).</div><div><br></div><div>In the meantime, I'll summarize:</div><div><br></div><div>The plan is to merge GHC's type language with its kind language. That is, there will be no difference, at all, between types and kinds. So any type family is now also a kind family, you can have unsaturated kinds, etc. Having merged types and kinds, it is also convenient to have (* :: *). That is, the type of * will be *. Other languages (Idris/Coq/Agda) avoid this simplification (preferring something *0 :: *1 :: *2 :: *3 :: ...) because they require logical consistency in order to be type-safe. Haskell doesn't (for reasons that are beyond the scope of this email) so our type system can be simpler, at least in this regard.</div><div><br></div><div>The user-facing effects of this change should all be positive. All existing programs will continue to work (of course!), and I am being very careful not to degrade error messages. In particular, error messages will continue to mention types and kinds as separate entities, because this distinction is helpful to users. Kind parameters will remain invisible (implicit) in all code that compiles today.</div><div><br></div><div>But, new, wonderful things are allowed. Like these:</div><div><br></div><div>data Proxy k (a :: k) = Proxy -- note the visible (explicit) kind parameter k!</div><div><br></div><div>data (a :: k1) :~~: (b :: k2) where -- heterogeneous equality</div><div> HRefl :: a :~~: a</div><div><br></div><div>data G a where</div><div> MkG :: G Bool</div><div>data H a (g :: G a) where</div><div> MkH :: a -> H a g</div><div>foo :: H Bool 'MkG</div><div>foo = MkH True</div><div><br></div><div>type family KindOf (a :: k) :: *</div><div>type instance KindOf (a :: k) = k</div><div><br></div><div>... and other fun stuff.</div><div><br></div><div>Richard</div><br><div><div>On Jun 26, 2015, at 4:24 AM, Alp Mestanogullari <<a href="mailto:alpmestan@gmail.com">alpmestan@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">Hello,<div><br></div><div>Sorry to chime in, but Richard: could you expand a little bit on what your ongoing work there consists in and what will be possible that wasn't before? You got me quite curious here.</div><div><br></div><div>Thanks!</div></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Jun 25, 2015 at 2:31 PM, Richard Eisenberg <span dir="ltr"><<a href="mailto:eir@cis.upenn.edu" target="_blank">eir@cis.upenn.edu</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Косырев,<br>
<br>
Promoting type/data families isn't a matter of safety, exactly, but a matter of drastically altering the internal type system of GHC to support such things. Happily, my research is all about doing so. You can expect your first example `class C1 a (b :: D I)` to work in GHC 7.12. If you're overly interested, my work is happening at <a href="http://github.com/goldfirere/ghc" rel="noreferrer" target="_blank">github.com/goldfirere/ghc</a> on the `nokinds` branch. But there won't be much (any?) action there for a little while as I'm working on anther project for the next few weeks.<br>
<br>
Your second example, though, is ill-formed: you can't have a type variable of kind `D`, as `D`, by itself, isn't a kind. You could say this, if you wanted, though:<br>
<br>
> class C1 a (b :: D a)<br>
<br>
Do you have an use case for this? I'm always curious to see how Haskellers want to use these advanced features!<br>
<br>
Thanks,<br>
Richard<br>
<div class="HOEnZb"><div class="h5"><br>
On Jun 25, 2015, at 2:44 AM, Kosyrev Serge <_<a href="mailto:deepfire@feelingofgreen.ru">deepfire@feelingofgreen.ru</a>> wrote:<br>
<br>
> Good day!<br>
><br>
> DataKinds doesn't allow promotion of type/data families.<br>
><br>
> However, in the specific case of associated data families -- aren't<br>
> they constrained more, and sufficiently so that the following, for example,<br>
> could be made to work without stepping into dangerous territories:<br>
><br>
> --<br>
> {-# LANGUAGE DataKinds #-}<br>
> {-# LANGUAGE KindSignatures #-}<br>
> {-# LANGUAGE TypeFamilies #-}<br>
> {-# LANGUAGE UnicodeSyntax #-}<br>
><br>
> module M where<br>
><br>
> class C a where<br>
> data D a ∷ *<br>
><br>
> data I<br>
><br>
> instance C I where<br>
> data D I<br>
><br>
> class C1 a (b ∷ D I) where<br>
><br>
> -- ..or, maybe, perhaps even the following:<br>
><br>
> class C1 a (b ∷ D) where<br>
><br>
> --<br>
> respectfully,<br>
> Косырев Серёга<br>
> _______________________________________________<br>
> Haskell-Cafe mailing list<br>
> <a href="mailto:Haskell-Cafe@haskell.org">Haskell-Cafe@haskell.org</a><br>
> <a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe</a><br>
><br>
<br>
_______________________________________________<br>
Haskell-Cafe mailing list<br>
<a href="mailto:Haskell-Cafe@haskell.org">Haskell-Cafe@haskell.org</a><br>
<a href="http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe" rel="noreferrer" target="_blank">http://mail.haskell.org/cgi-bin/mailman/listinfo/haskell-cafe</a><br>
</div></div></blockquote></div><br><br clear="all"><div><br></div>-- <br><div class="gmail_signature">Alp Mestanogullari</div>
</div>
</blockquote></div><br></body></html>