| Index: swig/Lib/typemaps/ptrtypes.swg
|
| ===================================================================
|
| --- swig/Lib/typemaps/ptrtypes.swg (revision 0)
|
| +++ swig/Lib/typemaps/ptrtypes.swg (revision 0)
|
| @@ -0,0 +1,211 @@
|
| +/* -----------------------------------------------------------------------------
|
| + * See the LICENSE file for information on copyright, usage and redistribution
|
| + * of SWIG, and the README file for authors - http://www.swig.org/release.html.
|
| + *
|
| + * ptrtypes.swg
|
| + *
|
| + * Value typemaps (Type, const Type&) for "Ptr" types, such as swig
|
| + * wrapped classes, that define the AsPtr/From methods
|
| + *
|
| + * To apply them, just use one of the following macros:
|
| + *
|
| + * %typemaps_asptr(CheckCode, AsPtrMeth, AsPtrFrag, Type)
|
| + * %typemaps_asptrfrom(CheckCode, AsPtrMeth, FromMeth, AsPtrFrag, FromFrag, Type)
|
| + *
|
| + * or the simpler and normalize form:
|
| + *
|
| + * %typemaps_asptrfromn(CheckCode, Type)
|
| + *
|
| + * Also, you can use the individual typemap definitions:
|
| + *
|
| + * %ptr_in_typemap(asptr_meth,frag,Type)
|
| + * %ptr_varin_typemap(asptr_meth,frag,Type)
|
| + * %ptr_typecheck_typemap(check,asptr_meth,frag,Type)
|
| + * %ptr_directorout_typemap(asptr_meth,frag,Type)
|
| + * ----------------------------------------------------------------------------- */
|
| +
|
| +%include <typemaps/valtypes.swg>
|
| +
|
| +/* in */
|
| +
|
| +%define %ptr_in_typemap(asptr_meth,frag,Type...)
|
| + %typemap(in,fragment=frag) Type {
|
| + Type *ptr = (Type *)0;
|
| + int res = asptr_meth($input, &ptr);
|
| + if (!SWIG_IsOK(res) || !ptr) {
|
| + %argument_fail((ptr ? res : SWIG_TypeError), "$type", $symname, $argnum);
|
| + }
|
| + $1 = *ptr;
|
| + if (SWIG_IsNewObj(res)) %delete(ptr);
|
| + }
|
| + %typemap(freearg) Type "";
|
| + %typemap(in,fragment=frag) const Type & (int res = SWIG_OLDOBJ) {
|
| + Type *ptr = (Type *)0;
|
| + res = asptr_meth($input, &ptr);
|
| + if (!SWIG_IsOK(res)) { %argument_fail(res,"$type",$symname, $argnum); }
|
| + if (!ptr) { %argument_nullref("$type",$symname, $argnum); }
|
| + $1 = ptr;
|
| + }
|
| + %typemap(freearg,noblock=1) const Type & {
|
| + if (SWIG_IsNewObj(res$argnum)) %delete($1);
|
| + }
|
| +%enddef
|
| +
|
| +/* varin */
|
| +
|
| +%define %ptr_varin_typemap(asptr_meth,frag,Type...)
|
| + %typemap(varin,fragment=frag) Type {
|
| + Type *ptr = (Type *)0;
|
| + int res = asptr_meth($input, &ptr);
|
| + if (!SWIG_IsOK(res) || !ptr) {
|
| + %variable_fail((ptr ? res : SWIG_TypeError), "$type", "$name");
|
| + }
|
| + $1 = *ptr;
|
| + if (SWIG_IsNewObj(res)) %delete(ptr);
|
| + }
|
| +%enddef
|
| +
|
| +#if defined(SWIG_DIRECTOR_TYPEMAPS)
|
| +/* directorout */
|
| +
|
| +%define %ptr_directorout_typemap(asptr_meth,frag,Type...)
|
| + %typemap(directorargout,noblock=1,fragment=frag) Type *DIRECTOROUT ($*ltype temp) {
|
| + Type *swig_optr = 0;
|
| + int swig_ores = $input ? asptr_meth($input, &swig_optr) : 0;
|
| + if (!SWIG_IsOK(swig_ores) || !swig_optr) {
|
| + %dirout_fail((swig_optr ? swig_ores : SWIG_TypeError),"$type");
|
| + }
|
| + temp = *swig_optr;
|
| + $result = &temp;
|
| + if (SWIG_IsNewObj(swig_ores)) %delete(swig_optr);
|
| + }
|
| +
|
| + %typemap(directorout,noblock=1,fragment=frag) Type {
|
| + Type *swig_optr = 0;
|
| + int swig_ores = asptr_meth($input, &swig_optr);
|
| + if (!SWIG_IsOK(swig_ores) || !swig_optr) {
|
| + %dirout_fail((swig_optr ? swig_ores : SWIG_TypeError),"$type");
|
| + }
|
| + $result = *swig_optr;
|
| + if (SWIG_IsNewObj(swig_ores)) %delete(swig_optr);
|
| + }
|
| +
|
| + %typemap(directorout,noblock=1,fragment=frag,warning=SWIGWARN_TYPEMAP_DIRECTOROUT_PTR_MSG) Type* {
|
| + Type *swig_optr = 0;
|
| + int swig_ores = asptr_meth($input, &swig_optr);
|
| + if (!SWIG_IsOK(swig_ores)) {
|
| + %dirout_fail(swig_ores,"$type");
|
| + }
|
| + $result = swig_optr;
|
| + if (SWIG_IsNewObj(swig_ores)) {
|
| + swig_acquire_ownership(swig_optr);
|
| + }
|
| + }
|
| + %typemap(directorfree,noblock=1) Type*
|
| + {
|
| + if (director) {
|
| + director->swig_release_ownership(%as_voidptr($input));
|
| + }
|
| + }
|
| +
|
| + %typemap(directorout,noblock=1,fragment=frag,warning=SWIGWARN_TYPEMAP_DIRECTOROUT_PTR_MSG) Type& {
|
| + Type *swig_optr = 0;
|
| + int swig_ores = asptr_meth($input, &swig_optr);
|
| + if (!SWIG_IsOK(swig_ores)) {
|
| + %dirout_fail(swig_ores,"$type");
|
| + } else {
|
| + if (!swig_optr) {
|
| + %dirout_nullref("$type");
|
| + }
|
| + }
|
| + $result = swig_optr;
|
| + if (SWIG_IsNewObj(swig_ores)) {
|
| + swig_acquire_ownership(swig_optr);
|
| + }
|
| + }
|
| + %typemap(directorfree,noblock=1) Type&
|
| + {
|
| + if (director) {
|
| + director->swig_release_ownership(%as_voidptr($input));
|
| + }
|
| + }
|
| +
|
| +
|
| + %typemap(directorout,fragment=frag) Type &DIRECTOROUT = Type
|
| +
|
| +%enddef
|
| +
|
| +#else
|
| +
|
| +#define %ptr_directorout_typemap(asptr_meth,frag,Type...)
|
| +
|
| +#endif /* SWIG_DIRECTOR_TYPEMAPS */
|
| +
|
| +/* typecheck */
|
| +
|
| +%define %ptr_typecheck_typemap(check,asptr_meth,frag,Type...)
|
| +%typemap(typecheck,noblock=1,precedence=check,fragment=frag) Type * {
|
| + int res = asptr_meth($input, (Type**)(0));
|
| + $1 = SWIG_CheckState(res);
|
| +}
|
| +
|
| +%typemap(typecheck,noblock=1,precedence=check,fragment=frag) Type, const Type& {
|
| + int res = asptr_meth($input, (Type**)(0));
|
| + $1 = SWIG_CheckState(res);
|
| +}
|
| +%enddef
|
| +
|
| +
|
| +/*---------------------------------------------------------------------
|
| + * typemap definition for types with asptr method
|
| + *---------------------------------------------------------------------*/
|
| +
|
| +%define %typemaps_asptr(CheckCode, AsPtrMeth, AsPtrFrag, Type...)
|
| + %fragment(SWIG_AsVal_frag(Type),"header",fragment=SWIG_AsPtr_frag(Type)) {
|
| + SWIGINTERNINLINE int
|
| + SWIG_AsVal(Type)(SWIG_Object obj, Type *val)
|
| + {
|
| + Type *v = (Type *)0;
|
| + int res = SWIG_AsPtr(Type)(obj, &v);
|
| + if (!SWIG_IsOK(res)) return res;
|
| + if (v) {
|
| + if (val) *val = *v;
|
| + if (SWIG_IsNewObj(res)) {
|
| + %delete(v);
|
| + res = SWIG_DelNewMask(res);
|
| + }
|
| + return res;
|
| + }
|
| + return SWIG_ERROR;
|
| + }
|
| + }
|
| + %ptr_in_typemap(%arg(AsPtrMeth), %arg(AsPtrFrag), Type);
|
| + %ptr_varin_typemap(%arg(AsPtrMeth), %arg(AsPtrFrag), Type);
|
| + %ptr_directorout_typemap(%arg(AsPtrMeth), %arg(AsPtrFrag), Type);
|
| + %ptr_typecheck_typemap(%arg(CheckCode), %arg(AsPtrMeth),%arg(AsPtrFrag), Type);
|
| + %ptr_input_typemap(%arg(CheckCode),%arg(AsPtrMeth),%arg(AsPtrFrag),Type);
|
| +%enddef
|
| +
|
| +/*---------------------------------------------------------------------
|
| + * typemap definition for types with asptr/from methods
|
| + *---------------------------------------------------------------------*/
|
| +
|
| +%define %typemaps_asptrfrom(CheckCode, AsPtrMeth, FromMeth, AsPtrFrag, FromFrag, Type...)
|
| + %typemaps_asptr(%arg(CheckCode), %arg(AsPtrMeth), %arg(AsPtrFrag), Type)
|
| + %typemaps_from(%arg(FromMeth), %arg(FromFrag), Type);
|
| + %value_output_typemap(%arg(FromMeth), %arg(FromFrag), Type);
|
| + %ptr_inout_typemap(Type);
|
| +%enddef
|
| +
|
| +/*---------------------------------------------------------------------
|
| + * typemap definition for types with for 'normalized' asptr/from methods
|
| + *---------------------------------------------------------------------*/
|
| +
|
| +%define %typemaps_asptrfromn(CheckCode, Type...)
|
| +%typemaps_asptrfrom(%arg(CheckCode),
|
| + %arg(SWIG_AsPtr(Type)),
|
| + %arg(SWIG_From(Type)),
|
| + %arg(SWIG_AsPtr_frag(Type)),
|
| + %arg(SWIG_From_frag(Type)),
|
| + Type);
|
| +%enddef
|
|
|