diff options
author | tenderlove <tenderlove@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-02-03 01:23:48 +0000 |
---|---|---|
committer | tenderlove <tenderlove@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-02-03 01:23:48 +0000 |
commit | b386fe21eca01e03a5ca447792354632e549c94e (patch) | |
tree | 30b480ee3ab580e28053d1ec3f31a5fd5285aa9c /ext/dl/dl.h | |
parent | b378bda47c3960acd983890efd01ac08794f6fd3 (diff) | |
download | ruby-b386fe21eca01e03a5ca447792354632e549c94e.tar.gz |
Wed Feb 3 10:12:09 2010 Aaron Patterson <tenderlove@ruby-lang.org>
* ext/dl/function.c: DL::Function now uses libffi
* ext/dl/cfunc.c (rb_dl_set_last_error): set to non static so errors
can be exposed.
* ext/dl/closure.c: DL::Closure will now be used in place of
ext/dl/callback/*.
* ext/dl/dl.c: legacy callbacks removed in favor of libffi
* ext/dl/dl_converions.(c,h): used for converting ruby types to FFI
types.
* ext/dl/callback/*: replaced by libffi callbacks.
* ext/dl/lib/dl/callback.rb: Converting internal callbacks to use
DL::Closure
* ext/dl/lib/dl/closure.rb: Ruby parts of the new DL::Closure object
* ext/dl/lib/dl/import.rb: More conversion to use DL::Closure object
* ext/dl/lib/dl/value.rb (ruby2ffi): adding private method for
DL::CPtr to ffi value conversion.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@26545 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'ext/dl/dl.h')
-rw-r--r-- | ext/dl/dl.h | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/ext/dl/dl.h b/ext/dl/dl.h index d06cad4e6b..da5695d3fa 100644 --- a/ext/dl/dl.h +++ b/ext/dl/dl.h @@ -3,6 +3,12 @@ #include <ruby.h> +#ifdef USE_HEADER_HACKS +#include <ffi/ffi.h> +#else +#include <ffi.h> +#endif + #if !defined(FUNC_CDECL) # define FUNC_CDECL(x) x #endif @@ -221,4 +227,9 @@ VALUE rb_dlptr_new(void *ptr, long size, freefunc_t func); VALUE rb_dlptr_new2(VALUE klass, void *ptr, long size, freefunc_t func); VALUE rb_dlptr_malloc(long size, freefunc_t func); +VALUE rb_dl_set_last_error(VALUE self, VALUE val); +#if defined(HAVE_WINDOWS_H) +VALUE rb_dl_set_win32_last_error(VALUE self, VALUE val); +#endif + #endif |