Support namespaces and nspace with the interface feature for Java

This commit is contained in:
William S Fulton 2016-02-26 08:02:46 +00:00
commit 50fec04759
6 changed files with 665 additions and 24 deletions

View file

@ -1,29 +1,44 @@
%define DECLARE_INTERFACE_(INTERFACE, IMPL, CTYPE...)
%define DECLARE_INTERFACE_(INTERFACE, CTYPE...)
%feature("interface", name="INTERFACE") CTYPE;
%typemap(jtype) CTYPE, CTYPE *, CTYPE *const&, CTYPE [], CTYPE & "long"
%typemap(jstype) CTYPE, CTYPE *, CTYPE *const&, CTYPE [], CTYPE & "INTERFACE"
%typemap(jstype) CTYPE "$&interfacename"
%typemap(jstype) CTYPE *, CTYPE [], CTYPE & "$interfacename"
%typemap(jstype) CTYPE *const& "$*interfacename"
%typemap(javain) CTYPE, CTYPE & "$javainput." ## #INTERFACE ## "_SWIGInterfaceUpcast()"
%typemap(javain) CTYPE *, CTYPE *const&, CTYPE [] "($javainput == null) ? 0 : $javainput." ## #INTERFACE ## "_SWIGInterfaceUpcast()"
%typemap(javaout) CTYPE {
return (INTERFACE)new IMPL($jnicall, true);
return ($&interfacename)new $&javaclassname($jnicall, true);
}
%typemap(javaout) CTYPE & {
return (INTERFACE)new IMPL($jnicall, $owner);
return ($interfacename)new $javaclassname($jnicall, $owner);
}
%typemap(javaout) CTYPE *, CTYPE *const&, CTYPE [] {
%typemap(javaout) CTYPE *, CTYPE [] {
long cPtr = $jnicall;
return (cPtr == 0) ? null : (INTERFACE)new IMPL(cPtr, $owner);
return (cPtr == 0) ? null : ($interfacename)new $javaclassname(cPtr, $owner);
}
%typemap(javadirectorin) CTYPE, CTYPE & "(INTERFACE)new IMPL($jniinput, false)"
%typemap(javadirectorin) CTYPE *, CTYPE *const&, CTYPE [] "($jniinput == 0) ? null : (INTERFACE)new IMPL($jniinput, false)"
%typemap(javaout) CTYPE *const& {
long cPtr = $jnicall;
return (cPtr == 0) ? null : ($interfacename)new $javaclassname(cPtr, $owner);
}
%typemap(javadirectorin) CTYPE "($&interfacename)new $&javaclassname($jniinput, false)"
%typemap(javadirectorin) CTYPE & "($interfacename)new $javaclassname($jniinput, false)"
%typemap(javadirectorin) CTYPE *, CTYPE [] "($jniinput == 0) ? null : ($interfacename)new $javaclassname($jniinput, false)"
%typemap(javadirectorin) CTYPE *const& "($jniinput == 0) ? null : ($*interfacename)new $*javaclassname($jniinput, false)"
%typemap(javadirectorout) CTYPE, CTYPE *, CTYPE *const&, CTYPE [], CTYPE & "$javacall." ## #INTERFACE ## "_SWIGInterfaceUpcast()"
%typemap(directorin, descriptor="L$packagepath/" ## #INTERFACE ## ";") CTYPE *, CTYPE &, CTYPE *const&, CTYPE [], CTYPE &
%typemap(directorin,descriptor="L$packagepath/$&interfacename;") CTYPE
%{ $input = 0;
*(($&1_ltype*)&$input) = &$1;
%}
%typemap(javainterfacecode, declaration=" long $interfacename_SWIGInterfaceUpcast();\n", cptrmethod="$interfacename_SWIGInterfaceUpcast") CTYPE %{
public long $interfacename_SWIGInterfaceUpcast() {
return $imclassname.$javaclazzname$interfacename_SWIGInterfaceUpcast(swigCPtr);
*(($&1_ltype*)&$input) = &$1; %}
%typemap(directorin,descriptor="L$packagepath/$interfacename;") CTYPE *, CTYPE []
%{ *(($&1_ltype)&$input) = ($1_ltype) $1; %}
%typemap(directorin,descriptor="L$packagepath/$interfacename;") CTYPE &
%{ *($&1_ltype)&$input = ($1_ltype) &$1; %}
%typemap(directorin,descriptor="L$packagepath/$*interfacename;") CTYPE *const&
%{ *($&1_ltype)&$input = ($1_ltype) &$1; %}
%typemap(javainterfacecode, declaration=" long " ## #INTERFACE ## "_SWIGInterfaceUpcast();\n", cptrmethod=#INTERFACE ## "_SWIGInterfaceUpcast") CTYPE %{
public long INTERFACE##_SWIGInterfaceUpcast() {
return $imclassname.$javaclazzname##INTERFACE##_SWIGInterfaceUpcast(swigCPtr);
}
%}
SWIG_JAVABODY_PROXY(public, protected, CTYPE)
@ -31,10 +46,10 @@ SWIG_JAVABODY_PROXY(public, protected, CTYPE)
%define DECLARE_INTERFACE_RENAME(INTERFACE, IMPL, CTYPE...)
%rename (IMPL) CTYPE;
DECLARE_INTERFACE_(INTERFACE, IMPL, CTYPE)
DECLARE_INTERFACE_(INTERFACE, CTYPE)
%enddef
%define DECLARE_INTERFACE(INTERFACE, CTYPE...)
DECLARE_INTERFACE_(INTERFACE, CTYPE, CTYPE)
DECLARE_INTERFACE_(INTERFACE, CTYPE)
%enddef