Add member variable support for shared_ptr
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@10260 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
731180ac3e
commit
9b7042280c
3 changed files with 189 additions and 28 deletions
|
|
@ -7,9 +7,9 @@ debug = False
|
|||
class li_boost_shared_ptr_runme:
|
||||
def main(self):
|
||||
if (debug):
|
||||
System.out.println("Started")
|
||||
print "Started"
|
||||
|
||||
li_boost_shared_ptr.debug_shared = debug
|
||||
li_boost_shared_ptr.cvar.debug_shared = debug
|
||||
|
||||
# Change loop count to run for a long time to monitor memory
|
||||
loopCount = 1 #5000
|
||||
|
|
@ -25,7 +25,7 @@ class li_boost_shared_ptr_runme:
|
|||
raise RuntimeError("shared_ptr wrapper count not zero: ", wrapper_count)
|
||||
|
||||
if (debug):
|
||||
System.out.println("Finished")
|
||||
print "Finished"
|
||||
|
||||
def runtest(self):
|
||||
# simple shared_ptr usage - created in C++
|
||||
|
|
@ -280,27 +280,172 @@ class li_boost_shared_ptr_runme:
|
|||
# //////////////////////////////// Overloading tests ////////////////////////////////////////
|
||||
# Base class
|
||||
k = li_boost_shared_ptr.Klass("me oh my")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyval(k), "rawbyval");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyref(k), "rawbyref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptr(k), "rawbyptr");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptrref(k), "rawbyptrref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyval(k), "rawbyval")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyref(k), "rawbyref")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptr(k), "rawbyptr")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptrref(k), "rawbyptrref")
|
||||
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyval(k), "smartbyval");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyref(k), "smartbyref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptr(k), "smartbyptr");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptrref(k), "smartbyptrref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyval(k), "smartbyval")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyref(k), "smartbyref")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptr(k), "smartbyptr")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptrref(k), "smartbyptrref")
|
||||
|
||||
# Derived class
|
||||
k = li_boost_shared_ptr.KlassDerived("me oh my")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyval(k), "rawbyval");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyref(k), "rawbyref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptr(k), "rawbyptr");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptrref(k), "rawbyptrref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyval(k), "rawbyval")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyref(k), "rawbyref")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptr(k), "rawbyptr")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_rawbyptrref(k), "rawbyptrref")
|
||||
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyval(k), "smartbyval");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyref(k), "smartbyref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptr(k), "smartbyptr");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptrref(k), "smartbyptrref");
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyval(k), "smartbyval")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyref(k), "smartbyref")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptr(k), "smartbyptr")
|
||||
self.verifyValue(li_boost_shared_ptr.overload_smartbyptrref(k), "smartbyptrref")
|
||||
|
||||
# //////////////////////////////// Member variables ////////////////////////////////////////
|
||||
# smart pointer by value
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
k = li_boost_shared_ptr.Klass("smart member value")
|
||||
m.SmartMemberValue = k
|
||||
val = k.getValue()
|
||||
self.verifyValue("smart member value", val)
|
||||
self.verifyCount(2, k)
|
||||
|
||||
kmember = m.SmartMemberValue
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("smart member value", val)
|
||||
self.verifyCount(3, kmember)
|
||||
self.verifyCount(3, k)
|
||||
|
||||
del m
|
||||
self.verifyCount(2, kmember)
|
||||
self.verifyCount(2, k)
|
||||
|
||||
# smart pointer by pointer
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
k = li_boost_shared_ptr.Klass("smart member pointer")
|
||||
m.SmartMemberPointer = k
|
||||
val = k.getValue()
|
||||
self.verifyValue("smart member pointer", val)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
kmember = m.SmartMemberPointer
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("smart member pointer", val)
|
||||
self.verifyCount(2, kmember)
|
||||
self.verifyCount(2, k)
|
||||
|
||||
del m
|
||||
self.verifyCount(2, kmember)
|
||||
self.verifyCount(2, k)
|
||||
|
||||
# smart pointer by reference
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
k = li_boost_shared_ptr.Klass("smart member reference")
|
||||
m.SmartMemberReference = k
|
||||
val = k.getValue()
|
||||
self.verifyValue("smart member reference", val)
|
||||
self.verifyCount(2, k)
|
||||
|
||||
kmember = m.SmartMemberReference
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("smart member reference", val)
|
||||
self.verifyCount(3, kmember)
|
||||
self.verifyCount(3, k)
|
||||
|
||||
# The C++ reference refers to SmartMemberValue...
|
||||
kmemberVal = m.SmartMemberValue
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("smart member reference", val)
|
||||
self.verifyCount(4, kmemberVal)
|
||||
self.verifyCount(4, kmember)
|
||||
self.verifyCount(4, k)
|
||||
|
||||
del m
|
||||
self.verifyCount(3, kmemberVal)
|
||||
self.verifyCount(3, kmember)
|
||||
self.verifyCount(3, k)
|
||||
|
||||
# plain by value
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
k = li_boost_shared_ptr.Klass("plain member value")
|
||||
m.MemberValue = k
|
||||
val = k.getValue()
|
||||
self.verifyValue("plain member value", val)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
kmember = m.MemberValue
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("plain member value", val)
|
||||
self.verifyCount(1, kmember)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
del m
|
||||
self.verifyCount(1, kmember)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
# plain by pointer
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
k = li_boost_shared_ptr.Klass("plain member pointer")
|
||||
m.MemberPointer = k
|
||||
val = k.getValue()
|
||||
self.verifyValue("plain member pointer", val)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
kmember = m.MemberPointer
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("plain member pointer", val)
|
||||
self.verifyCount(1, kmember)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
del m
|
||||
self.verifyCount(1, kmember)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
# plain by reference
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
k = li_boost_shared_ptr.Klass("plain member reference")
|
||||
m.MemberReference = k
|
||||
val = k.getValue()
|
||||
self.verifyValue("plain member reference", val)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
kmember = m.MemberReference
|
||||
val = kmember.getValue()
|
||||
self.verifyValue("plain member reference", val)
|
||||
self.verifyCount(1, kmember)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
del m
|
||||
self.verifyCount(1, kmember)
|
||||
self.verifyCount(1, k)
|
||||
|
||||
# null member variables
|
||||
m = li_boost_shared_ptr.MemberVariables()
|
||||
|
||||
# shared_ptr by value
|
||||
k = m.SmartMemberValue
|
||||
if (k != None):
|
||||
raise RuntimeError("expected null")
|
||||
m.SmartMemberValue = None
|
||||
k = m.SmartMemberValue
|
||||
if (k != None):
|
||||
raise RuntimeError("expected null")
|
||||
self.verifyCount(0, k)
|
||||
|
||||
# plain by value
|
||||
try:
|
||||
m.MemberValue = None
|
||||
raise RuntimeError("Failed to catch null pointer")
|
||||
except ValueError:
|
||||
pass
|
||||
|
||||
# templates
|
||||
pid = li_boost_shared_ptr.PairIntDouble(10, 20.2)
|
||||
if (pid.baseVal1 != 20 or pid.baseVal2 != 40.4):
|
||||
raise RuntimeError("Base values wrong")
|
||||
if (pid.val1 != 10 or pid.val2 != 20.2):
|
||||
raise RuntimeError("Derived Values wrong")
|
||||
|
||||
def verifyValue(self, expected, got):
|
||||
if (expected != got):
|
||||
|
|
@ -308,8 +453,8 @@ class li_boost_shared_ptr_runme:
|
|||
|
||||
def verifyCount(self, expected, k):
|
||||
got = li_boost_shared_ptr.use_count(k)
|
||||
if (expected != got - 1): # less one additional reference for marshalling the object into use_count()
|
||||
raise RuntimeError("verify use_count failed. Expected: ", expected, " Got: ", got - 1)
|
||||
if (expected != got):
|
||||
raise RuntimeError("verify use_count failed. Expected: ", expected, " Got: ", got)
|
||||
|
||||
|
||||
runme = li_boost_shared_ptr_runme()
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue