scope of header files

Simon Marlow marlowsd at gmail.com
Thu Apr 3 12:47:31 EDT 2008


Simon Marlow wrote:
> John Meacham wrote:
>> On Tue, Mar 11, 2008 at 02:47:37PM -0700, Simon Marlow wrote:
>>> Yeah, I'd like -fvia-C to be headerless.  We talked about it a while 
>>> back (on the haskell-prime list I think).  The main issue is that GHC 
>>> would have to generate prototypes based on the FFI declaration, and 
>>> since it can't guarantee to generate a prototype that is exactly the 
>>> same as the C prototype given in the header file (e.g. it doesn't 
>>> know about const), we would have to ensure that there really are no 
>>> other prototypes in scope, to prevent errors from the C compiler.
>>
>> I was thinking that you just wouldn't include any extra c headers at all
>> then, just write out the appropriate c code to call with the conventions
>> specified in the ffi import specification and you won't need external
>> headers at all so there isn't anything to conflict with.
> 
> Yes, pretty much.  There are a bunch of C headers that define the macros 
> used by the generated C code, and we have to be careful that they don't 
> include anything external - in the past we used to #include several 
> things from /usr/include, but I think we're much cleaner these days.

FYI, I've now done this: GHC 6.10 will consistently ignore c-includes 
and header files in FFI declarations.

Cheers,
	Simon



More information about the Glasgow-haskell-users mailing list