SWIGTYPE && input typemaps now assume object has been moved
Replicated Java implementation. Fully implemented for: - C# - D - Guile - Javascript (UTL) - Lua - MzScheme - Octave (UTL) - Perl (UTL) - PHP - Python (UTL) - Ruby (UTL) - Tcl (UTL) PHP std::auto_ptr std::unique_ptr minor tweaks and testcase corrections
This commit is contained in:
parent
0634883089
commit
e139a36511
31 changed files with 931 additions and 46 deletions
|
|
@ -0,0 +1,52 @@
|
|||
from cpp11_rvalue_reference_move_input import *
|
||||
|
||||
# Function containing rvalue reference parameter
|
||||
Counter.reset_counts()
|
||||
mo = MovableCopyable(222)
|
||||
Counter.check_counts(1, 0, 0, 0, 0, 0)
|
||||
MovableCopyable.movein(mo)
|
||||
Counter.check_counts(1, 0, 0, 1, 0, 2)
|
||||
if not MovableCopyable.is_nullptr(mo):
|
||||
raise RuntimeError("is_nullptr check")
|
||||
del mo
|
||||
Counter.check_counts(1, 0, 0, 1, 0, 2)
|
||||
|
||||
# Move constructor test
|
||||
Counter.reset_counts()
|
||||
mo = MovableCopyable(222)
|
||||
Counter.check_counts(1, 0, 0, 0, 0, 0)
|
||||
mo_moved = MovableCopyable(mo)
|
||||
Counter.check_counts(1, 0, 0, 1, 0, 1)
|
||||
if not MovableCopyable.is_nullptr(mo):
|
||||
raise RuntimeError("is_nullptr check")
|
||||
del mo
|
||||
Counter.check_counts(1, 0, 0, 1, 0, 1)
|
||||
del mo_moved
|
||||
Counter.check_counts(1, 0, 0, 1, 0, 2)
|
||||
|
||||
# Move assignment operator test
|
||||
Counter.reset_counts()
|
||||
mo111 = MovableCopyable(111)
|
||||
mo222 = MovableCopyable(222)
|
||||
Counter.check_counts(2, 0, 0, 0, 0, 0)
|
||||
mo111.MoveAssign(mo222)
|
||||
Counter.check_counts(2, 0, 0, 0, 1, 1)
|
||||
if not MovableCopyable.is_nullptr(mo222):
|
||||
raise RuntimeError("is_nullptr check")
|
||||
del mo222
|
||||
Counter.check_counts(2, 0, 0, 0, 1, 1)
|
||||
del mo111
|
||||
Counter.check_counts(2, 0, 0, 0, 1, 2)
|
||||
|
||||
# null check
|
||||
Counter.reset_counts()
|
||||
exception_thrown = False
|
||||
try:
|
||||
MovableCopyable.movein(None)
|
||||
except ValueError as e:
|
||||
if "invalid null reference" not in str(e):
|
||||
raise RuntimeError("incorrect exception message:" + str(e))
|
||||
exception_thrown = True
|
||||
if not exception_thrown:
|
||||
raise RuntimeError("Should have thrown null error")
|
||||
Counter.check_counts(0, 0, 0, 0, 0, 0)
|
||||
Loading…
Add table
Add a link
Reference in a new issue