4 #define SafeStringValueCStr(v) (rb_check_safe_obj(rb_string_value(&v)), StringValueCStr(v))
19 MEMORY_BASIC_INFORMATION
m;
21 if( !VirtualQuery(_errno, &m,
sizeof(m)) )
return NULL;
22 return m.AllocationBase;
27 w32_dlclose(
void *
ptr)
30 if( ptr == w32_coredll() )
return 0;
32 if( FreeLibrary((HMODULE)ptr) )
return 0;
35 #define dlclose(ptr) w32_dlclose(ptr)
43 dlclose(fiddle_handle->
ptr);
51 return ptr ?
sizeof(
struct dl_handle) : 0;
72 if(fiddle_handle->
open) {
73 int ret = dlclose(fiddle_handle->
ptr);
74 fiddle_handle->
open = 0;
78 #if defined(HAVE_DLERROR)
98 fiddle_handle->
ptr = 0;
99 fiddle_handle->
open = 0;
111 fiddle_handle->
ptr = handle;
112 fiddle_handle->
open = 1;
145 cflag = RTLD_LAZY | RTLD_GLOBAL;
149 cflag = RTLD_LAZY | RTLD_GLOBAL;
156 rb_bug(
"rb_fiddle_handle_new");
163 HANDLE rb_libruby_handle(
void);
164 ptr = rb_libruby_handle();
173 ptr = dlopen(
"coredll.dll", cflag);
180 ptr = dlopen(clib, cflag);
181 #if defined(HAVE_DLERROR)
182 if( !ptr && (err = dlerror()) ){
193 dlclose(fiddle_handle->
ptr);
196 fiddle_handle->
open = 1;
283 if( ! fiddle_handle->
open ){
291 #define RTLD_NEXT NULL
294 #define RTLD_DEFAULT NULL
316 #if defined(HAVE_DLERROR)
318 # define CHECK_DLERROR if( err = dlerror() ){ func = 0; }
320 # define CHECK_DLERROR
331 #if defined(FUNC_STDCALL)
336 #if defined(__CYGWIN__) || defined(_WIN32) || defined(__MINGW32__)
338 char *name_a = (
char*)
xmalloc(len+2);
342 name_a[len+1] =
'\0';
343 func = dlsym(handle, name_a);
345 if(
func )
goto found;
349 name_n = (
char*)
xmalloc(len+6);
351 memcpy(name_n, name, len);
353 for( i = 0; i < 256; i += 4 ){
354 sprintf(name_n + len,
"%d", i);
355 func = dlsym(handle, name_n);
359 if(
func )
goto found;
362 for( i = 0; i < 256; i += 4 ){
363 sprintf(name_n + len,
"%d", i);
364 func = dlsym(handle, name_n);
void rb_bug(const char *fmt,...)
size_t strlen(const char *)
static VALUE rb_fiddle_handle_close(VALUE self)
void rb_define_singleton_method(VALUE obj, const char *name, VALUE(*func)(ANYARGS), int argc)
Defines a singleton method for obj.
SSL_METHOD *(* func)(void)
void rb_define_alloc_func(VALUE, rb_alloc_func_t)
static VALUE rb_fiddle_handle_sym(VALUE self, VALUE sym)
VALUE rb_define_class_under(VALUE outer, const char *name, VALUE super)
Defines a class under the namespace of outer.
void rb_raise(VALUE exc, const char *fmt,...)
static VALUE rb_fiddle_handle_s_allocate(VALUE klass)
int rb_w32_map_errno(DWORD)
static VALUE rb_fiddle_handle_disable_close(VALUE self)
void Init_fiddle_handle(void)
memset(y->frac+ix+1, 0,(y->Prec-(ix+1))*sizeof(BDIGIT))
static VALUE predefined_fiddle_handle(void *handle)
#define TypedData_Get_Struct(obj, type, data_type, sval)
int rb_block_given_p(void)
#define STRCASECMP(s1, s2)
void rb_define_const(VALUE, const char *, VALUE)
sprintf(psz,"E%"PRIdSIZE, ex)
static size_t fiddle_handle_memsize(const void *ptr)
static VALUE rb_fiddle_handle_initialize(int argc, VALUE argv[], VALUE self)
static VALUE rb_fiddle_handle_close_enabled_p(VALUE self)
int rb_scan_args(int argc, const VALUE *argv, const char *fmt,...)
VALUE rb_ensure(VALUE(*b_proc)(ANYARGS), VALUE data1, VALUE(*e_proc)(ANYARGS), VALUE data2)
static const rb_data_type_t fiddle_handle_data_type
static VALUE rb_fiddle_handle_to_i(VALUE self)
#define SafeStringValueCStr(v)
#define TypedData_Make_Struct(klass, type, data_type, sval)
static VALUE rb_fiddle_handle_enable_close(VALUE self)
RUBY_EXTERN VALUE rb_cObject
static VALUE fiddle_handle_sym(void *handle, VALUE symbol)
static void fiddle_handle_free(void *ptr)
void rb_define_method(VALUE klass, const char *name, VALUE(*func)(ANYARGS), int argc)
static VALUE rb_fiddle_handle_s_sym(VALUE self, VALUE sym)