interface feature support for passing by value
Also add in missing $owner for governing ownership when returning pointers and references
This commit is contained in:
parent
3eec3e2ea5
commit
a1f2d60535
4 changed files with 92 additions and 24 deletions
|
|
@ -1,14 +1,23 @@
|
|||
%define DECLARE_INTERFACE_(CTYPE, INTERFACE, IMPL)
|
||||
%feature("interface", name = "INTERFACE", cptr = "GetCPtr") CTYPE;
|
||||
%typemap(cstype) CTYPE *, CTYPE & "INTERFACE"
|
||||
%typemap(csdirectorout) CTYPE *, CTYPE & "$cscall.GetCPtr()"
|
||||
%typemap(csdirectorin) CTYPE *, CTYPE & "(INTERFACE)new IMPL($iminput, false)"
|
||||
%typemap(cstype) CTYPE, CTYPE *, CTYPE & "INTERFACE"
|
||||
%typemap(csin) CTYPE, CTYPE & "$csinput.GetCPtr()"
|
||||
%typemap(csin) CTYPE * "$csinput == null ? new HandleRef(null, IntPtr.Zero) : $csinput.GetCPtr()"
|
||||
%typemap(csin) CTYPE & "$csinput.GetCPtr()"
|
||||
%typemap(csout, excode=SWIGEXCODE) CTYPE *, CTYPE & {
|
||||
%typemap(csout, excode=SWIGEXCODE) CTYPE {
|
||||
IMPL ret = new IMPL($imcall, true);$excode
|
||||
return (INTERFACE)ret;
|
||||
}
|
||||
%typemap(csout, excode=SWIGEXCODE) CTYPE & {
|
||||
IMPL ret = new IMPL($imcall, $owner);$excode
|
||||
return (INTERFACE)ret;
|
||||
}
|
||||
%typemap(csout, excode=SWIGEXCODE) CTYPE * {
|
||||
IMPL ret = (cPtr == IntPtr.Zero) ? null : new IMPL($imcall, $owner);$excode
|
||||
return (INTERFACE)ret;
|
||||
}
|
||||
%typemap(csdirectorin) CTYPE, CTYPE & "(INTERFACE)new IMPL($iminput, false)"
|
||||
%typemap(csdirectorin) CTYPE * "($iminput == IntPtr.Zero) ? null : (INTERFACE)new IMPL($iminput, false)"
|
||||
%typemap(csdirectorout) CTYPE, CTYPE *, CTYPE & "$cscall.GetCPtr()"
|
||||
%enddef
|
||||
|
||||
%define DECLARE_INTERFACE_RENAME(CTYPE, INTERFACE, IMPL)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue