/* ----------------------------------------------------------------------------- * std_auto_ptr.i * * The typemaps here allow handling functions returning std::auto_ptr<>, * which is the most common use of this type. If you have functions taking it * as parameter, these typemaps can't be used for them and you need to do * something else (e.g. use shared_ptr<> which SWIG supports fully). * ----------------------------------------------------------------------------- */ %define %auto_ptr(TYPE) %typemap (jni) std::auto_ptr< TYPE > "jlong" %typemap (jtype) std::auto_ptr< TYPE > "long" %typemap (jstype) std::auto_ptr< TYPE > "$typemap(jstype, TYPE)" %typemap (out) std::auto_ptr< TYPE > %{ jlong lpp = 0; *(TYPE **) &lpp = $1.release(); $result = lpp; %} %typemap(javaout) std::auto_ptr< TYPE > { long cPtr = $jnicall; return (cPtr == 0) ? null : new $typemap(jstype, TYPE)(cPtr, true); } %template() std::auto_ptr< TYPE >; %enddef namespace std { template class auto_ptr {}; }