API function to check whether one type fits "in" another

Simon Peyton-Jones simonpj at microsoft.com
Fri Jun 29 18:00:03 CEST 2012


Philip

If you develop a function that does what you want, and want to make it part of the GHC API, we'd definitely consider including it.  But I don't want to promise to develop something just for you; I'm just too snowed under with other stuff.

I really think the "holes" that Thijs is working on might be good for you.  He has a prototype already I think.

Simon

|  -----Original Message-----
|  From: "Philip K. F. Hölzenspies" [mailto:pkfh at st-andrews.ac.uk]
|  Sent: 28 June 2012 11:11
|  To: Simon Peyton-Jones
|  Cc: thijsalkemade at gmail.com; glasgow-haskell-users at haskell.org
|  Subject: Re: API function to check whether one type fits "in" another
|  
|  Dear Simon, et al,
|  
|  Thank you very much for your reply. Some of the pointers you gave, I wouldn't
|  have come across, for not knowing to have to browse through the module Inst, for
|  example.
|  
|  I read the OutsideIn paper (JFP), but that's a fair while back. I was pointed to
|  Thijs's work in progress at an Agda talk recently. The front-end we're working on
|  should be portable to any lambda-language with strong types, so the availability
|  of holes in Agda and Idris makes the implementation for those back-ends a
|  breeze.
|  
|  There is one limiting consideration, however: We want to get this up and running
|  the next few weeks and we would like to keep things in-sync with the
|  developments on the different back-ends. This is why I'm trying to stay as close
|  as possible to the more "public" API parts (the things that are documented and
|  haven't changed significantly since at least 7.0.4).
|  
|  In this light, I was wondering whether it's not worth having a function that does
|  all this plumbing in the API that is persistent through future versions, much like
|  pure interface to the parser (GHC.parser). Preferably it would look something like:
|  
|  typeCheck
|  	:: DynFlags   -- the flags
|  	-> FilePath   -- for source locations
|  	-> Type   -- expected
|  	-> Type   -- actual
|  	-> Either
|  		SomeSortOfErrorStructure
|  		SomeSubstitutionAndOrConstraintTable
|  
|  The implementation would have to make sure the pre-conditions of the type
|  arguments are met. Is this worth pursuing? Would be a significant amount of
|  work? Am I being pushy if I make this a feature-request?
|  
|  Regards,
|  Philip
|  
|  PS. I'm going to study the Trac you pointed to in more detail; browsing it was
|  already a learning experience about the whats and wheres of the GHC API.




More information about the Glasgow-haskell-users mailing list