diff options
Diffstat (limited to 'Lib/ruby')
-rw-r--r-- | Lib/ruby/cstring.i | 9 | ||||
-rw-r--r-- | Lib/ruby/rubyapi.swg | 2 | ||||
-rw-r--r-- | Lib/ruby/rubyprimtypes.swg | 197 | ||||
-rw-r--r-- | Lib/ruby/rubyrun.swg | 12 | ||||
-rw-r--r-- | Lib/ruby/rubystrings.swg | 12 | ||||
-rw-r--r-- | Lib/ruby/rubytypemaps.swg | 28 | ||||
-rw-r--r-- | Lib/ruby/rubywstrings.swg | 74 | ||||
-rw-r--r-- | Lib/ruby/std_string.i | 29 |
8 files changed, 63 insertions, 300 deletions
diff --git a/Lib/ruby/cstring.i b/Lib/ruby/cstring.i index 8ac2d55ce..ede9c596a 100644 --- a/Lib/ruby/cstring.i +++ b/Lib/ruby/cstring.i @@ -1,10 +1 @@ %include <typemaps/cstring.swg> -%include <rubystrings.swg> - -%typemap_cstrings(%cstring, - char, - SWIG_AsCharPtr, - SWIG_AsCharPtrAndSize, - SWIG_FromCharPtr, - SWIG_FromCharPtrAndSize); - diff --git a/Lib/ruby/rubyapi.swg b/Lib/ruby/rubyapi.swg index 0563fd130..7883e9e6c 100644 --- a/Lib/ruby/rubyapi.swg +++ b/Lib/ruby/rubyapi.swg @@ -7,7 +7,7 @@ extern "C" { #endif SWIGINTERN VALUE -SWIG_Ruby_AppendResult(VALUE target, VALUE o) { +SWIG_Ruby_AppendOutput(VALUE target, VALUE o) { if (NIL_P(target)) { target = o; } else { diff --git a/Lib/ruby/rubyprimtypes.swg b/Lib/ruby/rubyprimtypes.swg index 41e0eb9b2..f1969cd1a 100644 --- a/Lib/ruby/rubyprimtypes.swg +++ b/Lib/ruby/rubyprimtypes.swg @@ -1,33 +1,30 @@ -%include <typemaps/primtypes.swg> - -/* Macro for 'signed long' derived types */ - -%define %type_slong(Type, Frag, Min, Max) -%derived_type_from(long, Type) -%signed_derived_type_asval(long, Type, Frag, Min, Max) -%enddef - -/* Macro for 'unsigned long' derived types */ - -%define %type_ulong(Type, Frag, Max) -%derived_type_from(unsigned long, Type) -%unsigned_derived_type_asval(unsigned long, Type, Frag, Max) -%enddef - /* ------------------------------------------------------------ * Primitive Types * ------------------------------------------------------------ */ +/* auxiliar ruby fail method */ + %fragment("SWIG_ruby_failed","header") { SWIGINTERN VALUE SWIG_ruby_failed() { return Qnil; +} } - + +%define %ruby_aux_method(Type, Method, Action) +SWIGINTERN VALUE SWIG_AUX_##Method##(VALUE *args) +{ + VALUE obj = args[0]; + VALUE type = TYPE(obj); + Type *res = (Type *)(args[1]); + *res = Action; + return obj; } +%enddef + /* boolean */ @@ -61,48 +58,24 @@ SWIG_AsVal_dec(bool)(VALUE obj, bool *val) } } -/* signed/unsigned char */ - -%type_slong(signed char, "<limits.h>", SCHAR_MIN, SCHAR_MAX) -%type_ulong(unsigned char, "<limits.h>", UCHAR_MAX) - -/* short/unsigned short */ - -%type_slong(short, "<limits.h>", SHRT_MIN, SHRT_MAX) -%type_ulong(unsigned short, "<limits.h>", USHRT_MAX) - -/* int/unsigned int */ - -%type_slong(int, "<limits.h>", INT_MIN, INT_MAX) -%type_ulong(unsigned int, "<limits.h>", UINT_MAX) - -/* signed/unsigned wchar_t */ - -#ifdef __cplusplus -%type_slong(signed wchar_t, "<wchar.h>", WCHAR_MIN, WCHAR_MAX) -%type_ulong(unsigned wchar_t, "<wchar.h>", UWCHAR_MAX) -#endif - /* long */ %fragment(SWIG_From_frag(long),"header", fragment="<limits.h>") { - SWIG_define(SWIG_From_dec(long), LONG2NUM) + %define_as(SWIG_From_dec(long), LONG2NUM) } %fragment(SWIG_AsVal_frag(long),"header",fragment="SWIG_ruby_failed") { -SWIGINTERN VALUE SWIG_num2long(VALUE *args) -{ - *((long *)(args[1])) = NUM2LONG(args[0]); - return args[0]; -} +%ruby_aux_method(long, NUM2LONG, type == T_FIXNUM ? NUM2LONG(obj) : rb_big2long(obj)) + SWIGINTERN int SWIG_AsVal_dec(long)(VALUE obj, long* val) { - if (obj != Qnil && ((TYPE(obj) == T_FIXNUM) || (TYPE(obj) == T_BIGNUM))) { + VALUE type = TYPE(obj); + if ((type == T_FIXNUM) || (type == T_BIGNUM)) { long v; VALUE a[2] = { obj, (VALUE)(&v) }; - if (rb_rescue(RUBY_METHOD_FUNC(SWIG_num2long), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { + if (rb_rescue(RUBY_METHOD_FUNC(SWIG_AUX_NUM2LONG), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { if (val) *val = v; return SWIG_OK; } @@ -123,18 +96,16 @@ SWIG_From_dec(unsigned long)(unsigned long value) } %fragment(SWIG_AsVal_frag(unsigned long),"header",fragment="SWIG_ruby_failed") { -SWIGINTERN VALUE SWIG_num2ulong(VALUE *args) -{ - *((unsigned long *)(args[1])) = NUM2ULONG(args[0]); - return args[0]; -} +%ruby_aux_method(unsigned long, NUM2ULONG, type == T_FIXNUM ? NUM2ULONG(obj) : rb_big2ulong(obj)) + SWIGINTERN int SWIG_AsVal_dec(unsigned long)(VALUE obj, unsigned long *val) { - if (obj != Qnil && ((TYPE(obj) == T_FIXNUM) || (TYPE(obj) == T_BIGNUM))) { + VALUE type = TYPE(obj); + if ((type == T_FIXNUM) || (type == T_BIGNUM)) { unsigned long v; VALUE a[2] = { obj, (VALUE)(&v) }; - if (rb_rescue(RUBY_METHOD_FUNC(SWIG_num2ulong), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { + if (rb_rescue(RUBY_METHOD_FUNC(SWIG_AUX_NUM2ULONG), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { if (val) *val = v; return SWIG_OK; } @@ -156,18 +127,16 @@ SWIG_From_dec(long long)(long long value) } %fragment(SWIG_AsVal_frag(long long),"header",fragment="SWIG_ruby_failed") { -SWIGINTERN VALUE SWIG_num2longlong(VALUE *args) -{ - *((long long *)(args[1])) = NUM2LL(args[0]); - return args[0]; -} +%ruby_aux_method(long long, NUM2LL, type == T_FIXNUM ? NUM2LL(obj) : rb_big2ll(obj)) + SWIGINTERN int SWIG_AsVal_dec(long long)(VALUE obj, long long *val) { - if (obj != Qnil && ((TYPE(obj) == T_FIXNUM) || (TYPE(obj) == T_BIGNUM))) { + VALUE type = TYPE(obj); + if ((type == T_FIXNUM) || (type == T_BIGNUM)) { long long v; VALUE a[2] = { obj, (VALUE)(&v) }; - if (rb_rescue(RUBY_METHOD_FUNC(SWIG_num2longlong), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { + if (rb_rescue(RUBY_METHOD_FUNC(SWIG_AUX_NUM2LL), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { if (val) *val = v; return SWIG_OK; } @@ -189,18 +158,16 @@ SWIG_From_dec(unsigned long long)(unsigned long long value) } %fragment(SWIG_AsVal_frag(unsigned long long),"header",fragment="SWIG_ruby_failed") { -SWIGINTERN VALUE SWIG_num2ulonglong(VALUE *args) -{ - *((unsigned long long *)(args[1])) = NUM2ULL(args[0]); - return args[0]; -} +%ruby_aux_method(long long, NUM2ULL, type == T_FIXNUM ? NUM2ULL(obj) : rb_big2ull(obj)) + SWIGINTERN int SWIG_AsVal_dec(unsigned long long)(VALUE obj, unsigned long long *val) -{ - if (obj != Qnil && ((TYPE(obj) == T_FIXNUM) || (TYPE(obj) == T_BIGNUM))) { +{ + VALUE type = TYPE(obj); + if ((type == T_FIXNUM) || (type == T_BIGNUM)) { unsigned long long v; VALUE a[2] = { obj, (VALUE)(&v) }; - if (rb_rescue(RUBY_METHOD_FUNC(SWIG_num2ulonglong), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { + if (rb_rescue(RUBY_METHOD_FUNC(SWIG_AUX_NUM2ULL), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { if (val) *val = v; return SWIG_OK; } @@ -209,30 +176,23 @@ SWIG_AsVal_dec(unsigned long long)(VALUE obj, unsigned long long *val) } } -/* float */ - -%derived_type_from(double, float) -%signed_derived_type_asval(double, float, "<float.h>", -FLT_MAX, FLT_MAX) - /* double */ %fragment(SWIG_From_frag(double),"header") { - SWIG_define(SWIG_From_dec(double), rb_float_new) + %define_as(SWIG_From_dec(double), rb_float_new) } %fragment(SWIG_AsVal_frag(double),"header",fragment="SWIG_ruby_failed") { -SWIGINTERN VALUE SWIG_num2dbl(VALUE *args) -{ - *((double *)(args[1])) = NUM2DBL(args[0]); - return args[0]; -} +%ruby_aux_method(double, NUM2DBL, (type == T_FLOAT ? NUM2DBL(obj) : (type == T_FIXNUM ? (double) FIX2INT(obj) : rb_big2dbl(obj)))) + SWIGINTERN int SWIG_AsVal_dec(double)(VALUE obj, double *val) { - if (obj != Qnil &&((TYPE(obj) == T_FLOAT) || (TYPE(obj) == T_FIXNUM) || (TYPE(obj) == T_BIGNUM))) { + VALUE type = TYPE(obj); + if ((type == T_FLOAT) || (type == T_FIXNUM) || (type == T_BIGNUM)) { double v; VALUE a[2] = { obj, (VALUE)(&v) }; - if (rb_rescue(RUBY_METHOD_FUNC(SWIG_num2dbl), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { + if (rb_rescue(RUBY_METHOD_FUNC(SWIG_AUX_NUM2DBL), (VALUE)a, RUBY_METHOD_FUNC(SWIG_ruby_failed), 0) != Qnil) { if (val) *val = v; return SWIG_OK; } @@ -241,77 +201,4 @@ SWIG_AsVal_dec(double)(VALUE obj, double *val) } } -/* char */ - -%fragment(SWIG_From_frag(char),"header") { -SWIGINTERNINLINE VALUE -SWIG_From_dec(char)(char c) -{ - return rb_str_new(&c,1); -} -} - -%fragment(SWIG_AsVal_frag(char),"header", - fragment="SWIG_AsCharArray", - fragment=SWIG_AsVal_frag(signed char)) { -SWIGINTERN int -SWIG_AsVal_dec(char)(VALUE obj, char *val) -{ - signed char v; - if (SWIG_AsVal(signed char)(obj, &v) == SWIG_OK) { - if (val) *val = (char)(v); - return SWIG_OK; - } else { - if (SWIG_AsCharArray(obj, val, 1) == SWIG_OK) { - return SWIG_OK; - } - } - return SWIG_TypeError; - } -} - -/* wchar_t */ - - -%fragment(SWIG_From_frag(wchar_t),"header", - fragment=SWIG_From_frag(char), - fragment=SWIG_From_frag(long)) { -SWIGINTERNINLINE VALUE -SWIG_From_dec(wchar_t)(wchar_t c) -{ - if (CHAR_MIN <= v && v <= CHAR_MAX) { - return SWIG_From(char)((char)c); - } else { - return SWIG_From(long)((long)c); - } -} -} - -%fragment(SWIG_AsVal_frag(wchar_t),"header", - fragment="SWIG_AsWCharArray", - fragment=SWIG_AsVal_frag(long)) { -SWIGINTERN int -SWIG_AsVal_dec(wchar_t)(VALUE obj, wchar_t *val) -{ - char v; - if (SWIG_AsVal(char)(obj, &v) == SWIG_OK) { - if (val) *val = (wchar_t)(v); - return SWIG_OK; - } else { - long v; - if (SWIG_AsVal(long)(obj, &v) == SWIG_OK) { - if (WCHAR_MIN <= v && v <= WCHAR_MAX) { - if (val) *val = (wchar_t)(v); - return SWIG_OK; - } - } - } - return SWIG_TypeError; -} -} - -/* ------------------------------------------------------------ - * Apply the primitive typemap for all the types with checkcode - * ------------------------------------------------------------ */ -%apply_checkctypes(%typemap_primitive) diff --git a/Lib/ruby/rubyrun.swg b/Lib/ruby/rubyrun.swg index cb894f909..4ecb3281d 100644 --- a/Lib/ruby/rubyrun.swg +++ b/Lib/ruby/rubyrun.swg @@ -12,19 +12,19 @@ #define SWIG_NewPointerObj(ptr, type, flags) SWIG_Ruby_NewPointerObj(ptr, type, flags) /* for raw packed data */ -#define SWIG_ConvertPacked(obj, ptr, sz, ty, flags) SWIG_Ruby_ConvertPacked(obj, ptr, sz, ty, flags) -#define SWIG_NewPackedObj(ptr, sz, type, flags) SWIG_Ruby_NewPackedObj(ptr, sz, type) +#define SWIG_ConvertPacked(obj, ptr, sz, ty) SWIG_Ruby_ConvertPacked(obj, ptr, sz, ty, flags) +#define SWIG_NewPackedObj(ptr, sz, type) SWIG_Ruby_NewPackedObj(ptr, sz, type) /* for class or struct pointers */ #define SWIG_ConvertInstance(obj, pptr, type, flags) SWIG_Ruby_ConvertPtr(obj, pptr, type, flags) #define SWIG_NewInstanceObj(ptr, type, flags) SWIG_Ruby_NewPointerObj(ptr, type, flags) /* for C or C++ function pointers */ -#define SWIG_ConvertFunctionPtr(obj, pptr, type, flags) SWIG_Ruby_ConvertPtr(obj, pptr, type, flags) +#define SWIG_ConvertFunctionPtr(obj, pptr, type) SWIG_Ruby_ConvertPtr(obj, pptr, type, 0) #define SWIG_NewFunctionPtrObj(ptr, type) SWIG_Ruby_NewPointerObj(ptr, type, 0) /* for C++ member pointers, ie, member methods */ -#define SWIG_ConvertMember(obj, ptr, sz, ty, flags) SWIG_Ruby_ConvertPacked(obj, ptr, sz, ty, flags) +#define SWIG_ConvertMember(obj, ptr, sz, ty) SWIG_Ruby_ConvertPacked(obj, ptr, sz, ty) #define SWIG_NewMemberObj(ptr, sz, type) SWIG_Ruby_NewPackedObj(ptr, sz, type) @@ -44,7 +44,7 @@ /* Ruby-specific SWIG API */ #define SWIG_InitRuntime() SWIG_Ruby_InitRuntime() -#define SWIG_define_class(ty) SWIG_Ruby_define_class(ty) +#define SWIG_define_class(ty) SWIG_Ruby_define_class(ty) #define SWIG_NewClassInstance(value, ty) SWIG_Ruby_NewClassInstance(value, ty) #define SWIG_MangleStr(value) SWIG_Ruby_MangleStr(value) #define SWIG_CheckConvert(value, ty) SWIG_Ruby_CheckConvert(value, ty) @@ -243,7 +243,7 @@ SWIG_Ruby_NewPackedObj(void *ptr, int sz, swig_type_info *type) { /* Convert a packed value value */ SWIGRUNTIME int -SWIG_Ruby_ConvertPacked(VALUE obj, void *ptr, int sz, swig_type_info *ty, int flags) { +SWIG_Ruby_ConvertPacked(VALUE obj, void *ptr, int sz, swig_type_info *ty) { swig_cast_info *tc; const char *c; diff --git a/Lib/ruby/rubystrings.swg b/Lib/ruby/rubystrings.swg index 53c587b86..cbe20a712 100644 --- a/Lib/ruby/rubystrings.swg +++ b/Lib/ruby/rubystrings.swg @@ -21,7 +21,7 @@ SWIG_AsCharPtrAndSize(VALUE obj, char** cptr, size_t* psize, int *alloc) if (cptr) { if (alloc) { if (*alloc == SWIG_NEWOBJ) { - *cptr = SWIG_new_copy_array(cstr, size, char); + *cptr = %new_copy_array(cstr, size, char); } else { *cptr = cstr; *alloc = SWIG_OLDOBJ; @@ -42,9 +42,9 @@ SWIG_FromCharPtrAndSize(const char* carray, size_t size) { if (carray) { if (size > LONG_MAX) { - return SWIG_NewPointerObj(SWIG_const_cast(carray,char *), SWIG_TypeQuery("char *"), 0); + return SWIG_NewPointerObj(%const_cast(carray,char *), SWIG_TypeQuery("char *"), 0); } else { - return rb_str_new(carray, SWIG_numeric_cast(size,long)); + return rb_str_new(carray, %numeric_cast(size,long)); } } else { return Qnil; @@ -52,9 +52,3 @@ SWIG_FromCharPtrAndSize(const char* carray, size_t size) } } -/* ------------------------------------------------------------ - * The plain char * handling - * ------------------------------------------------------------ */ - -%include <typemaps/strings.swg> -%typemap_string(char, Char, SWIG_AsCharPtrAndSize, SWIG_FromCharPtrAndSize, strlen) diff --git a/Lib/ruby/rubytypemaps.swg b/Lib/ruby/rubytypemaps.swg index c555921f3..7110b80bb 100644 --- a/Lib/ruby/rubytypemaps.swg +++ b/Lib/ruby/rubytypemaps.swg @@ -10,37 +10,31 @@ /* ----------------------------------------------------------------------------- * Basic definitions * ----------------------------------------------------------------------------- */ +#define %convertptr_flags $track +#define %newpointer_flags $track +#define %newinstance_flags $track -%define_swig_object(VALUE) +#define SWIG_Object VALUE +#define VOID_Object Qnil -#define SWIG_VoidObject() Qnil -#define SWIG_SetResultObj(obj) $result = obj -#define SWIG_AppendResultObj(obj) $result = SWIG_Ruby_AppendResult($result, obj) -#define SWIG_SetConstantObj(name, obj) rb_define_const($module, name, obj) -#define SWIG_Raise(obj, type, desc) rb_exc_raise(rb_exc_new3(rb_eRuntimeError, rb_obj_as_string(obj))) -#define SWIG_DirOutFail(code, msg) Swig::DirectorTypeMismatchException::raise(SWIG_ErrorType(code), msg) +#define SWIG_AppendOutput(result,obj) SWIG_Ruby_AppendOutput(result, obj) +#define SWIG_SetConstant(name, obj) rb_define_const($module, name, obj) +#define SWIG_Raise(obj, type, desc) rb_exc_raise(rb_exc_new3(rb_eRuntimeError, rb_obj_as_string(obj))) +#define SWIG_DirOutFail(code, msg) Swig::DirectorTypeMismatchException::raise(SWIG_ErrorType(code), msg) /* ----------------------------------------------------------------------------- * All the typemaps * ----------------------------------------------------------------------------- */ -%include <typemaps/exception.swg> -%include <typemaps/swigtype.swg> -%include <typemaps/void.swg> -%include <typemaps/valtypes.swg> -%include <typemaps/ptrtypes.swg> -%include <typemaps/swigobject.swg> -%include <typemaps/inoutlist.swg> %include <rubyprimtypes.swg> %include <rubystrings.swg> -%include <typemaps/misctypes.swg> -%include <typemaps/enumint.swg> +%include <typemaps/swigtypemaps.swg> /* ----------------------------------------------------------------------------- * Backward compatibility output helper * ----------------------------------------------------------------------------- */ %fragment("output_helper","header") %{ -#define output_helper SWIG_Ruby_AppendResult +#define output_helper SWIG_Ruby_AppendOutput %} diff --git a/Lib/ruby/rubywstrings.swg b/Lib/ruby/rubywstrings.swg deleted file mode 100644 index 4f4959844..000000000 --- a/Lib/ruby/rubywstrings.swg +++ /dev/null @@ -1,74 +0,0 @@ -/* ------------------------------------------------------------ - * utility methods for wchar_t strings - * ------------------------------------------------------------ */ - -/* - Ruby doesn't support the wchar_t, so, we need to use an 'opaque' type. - */ - -%types(ruby_wchar_array *); - -%fragment("ruby_wchar_array","header",fragment="<wchar.h>") { - struct ruby_wchar_array { - wchar_t *cptr; - size_t size; - }; - - SWIGINTERN get_ruby_wchar_array_info() { - static swig_type_info* ruby_wchar_array_info = 0; - if (!ruby_wchar_array_info) ruby_wchar_array_info = SWIG_TypeQuery("ruby_wchar_array *"); - return ruby_wchar_array_info; - } -} - -%fragment("SWIG_AsWCharPtrAndSize","header",fragment="ruby_wchar_array") { -SWIGINTERN int -SWIG_AsWCharPtrAndSize(PyObject *obj, wchar_t **cptr, size_t *psize, int *alloc) -{ - static swig_type_info* ptr_wchar_info = 0; - wchar_t * vptr = 0; - if (!ptr_wchar_info) ptr_wchar_info = SWIG_TypeQuery("wchar_t *"); - if (SWIG_ConvertPtr(obj, (void**)&vptr, ptr_wchar_info, 0) != SWIG_OK) { - if (cptr) *cptr = vptr; - if (psize) *psize = vptr ? (wcslen(vptr) + 1) : 0; - return SWIG_OK; - } else { - ruby_wchar_array *vptr = 0; - if (SWIG_ConvertPtr(obj, (void**)&vptr, get_ruby_wchar_array_info(), 0) != SWIG_OK) { - if (cptr) *cptr = vptr->cptr; - if (psize) *psize = vprtr->size; - return SWIG_OK; - } - } - return SWIG_TypeError; -} -} - -%fragment("SWIG_FromWCharPtrAndSize","header",fragment="ruby_wchar_array") { -SWIGINTERNINLINE PyObject * -SWIG_FromWCharPtrAndSize(const wchar_t * carray, size_t size) -{ - ruby_wchar_array *vptr = SWIG_new(ruby_wchar_array); - vptr->cptr = carray; - vptr->size = size; - return SWIG_NewPointerObj(SWIG_const_cast(carray,wchar_t *), get_ruby_wchar_array_info(), 1); -} -} - -%fragment("SWIG_FromWCharPtr","header",fragment="<wchar.h>") { -SWIGINTERNINLINE PyObject * -SWIG_FromWCharPtr(const wchar_t * carray) -{ - static swig_type_info* wchar_ptr_info = 0; - if (!wchar_array_info) wchar_ptr_info = SWIG_TypeQuery("wchar_t *"); - return SWIG_NewPointerObj(SWIG_const_cast(carray,wchar_t *), wchar_ptr_info, 0); -} -} - -/* ------------------------------------------------------------ - * The plain wchar_t * handling - * ------------------------------------------------------------ */ - -%include <typemaps/strbase.swg> -%typemap_string(wchar_t, WChar, SWIG_AsWCharPtrAndSize, SWIG_FromWCharPtrAndSize, wcslen); - diff --git a/Lib/ruby/std_string.i b/Lib/ruby/std_string.i index a0ec522bc..dc1378ae6 100644 --- a/Lib/ruby/std_string.i +++ b/Lib/ruby/std_string.i @@ -1,30 +1 @@ -// -// std::string -// - -#ifndef SWIG_STD_BASIC_STRING -#define SWIG_STD_STRING - -%{ -#include <string> -%} - -namespace std -{ - class string; -} - %include <typemaps/std_string.swg> -%include <rubystrings.swg> - -%std_string_asptr(std::string, char, SWIG_AsCharPtrAndSize) -%std_string_from(std::string, SWIG_FromCharPtrAndSize) -%std_string_asval(std::string) - -%typemap_asptrfromn(SWIG_CCode(STRING), std::string); - -#else - -%include <std/std_string.i> - -#endif |