Lateral change to add runtime "reprotection" at the python

side for protected director members.

Lib/python/director.swg: added needed code for runtime checking
Source/Modules/python.cxx: added needed code for runtime checking
director_protected_runme.py: checks now that the runtime protection is working


The extra runtime checking is only done for protected members,
so, the old public directors members don't feel any overhead.

This finished the director protected support for the python language.
Java and Ocalm will need to add the "reprotection" mechanism latter.
But as in the python case, the changes will be localized in the
languages files, and there will be no need to touch the core
files anymore.


git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@5532 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
Marcelo Matus 2003-12-11 01:59:12 +00:00
commit 72984676ca
4 changed files with 148 additions and 6 deletions

View file

@ -6,30 +6,54 @@ class FooBar(Bar):
def ping(self):
return "FooBar::ping();"
class FooBar2(Bar):
def ping(self):
return "FooBar2::ping();"
def pang(self):
return "FooBar2::pang();"
b = Bar()
f = b.create()
fb = FooBar()
fb2 = FooBar2()
try:
s1 = b.pong()
if s1 != "Bar::pong();Foo::pong();Bar::ping();":
s = fb.used()
if s != "Foo::pang();Bar::pong();Foo::pong();FooBar::ping();":
raise RuntimeError
pass
except:
raise RuntimeError, "bad FooBar::used"
try:
s = fb2.used()
if s != "FooBar2::pang();Bar::pong();Foo::pong();FooBar2::ping();":
raise RuntimeError
pass
except:
raise RuntimeError, "bad FooBar2::used"
try:
s = b.pong()
if s != "Bar::pong();Foo::pong();Bar::ping();":
raise RuntimeError
pass
except:
raise RuntimeError, "bad Bar::pong"
try:
s2 = f.pong()
if s2 != "Bar::pong();Foo::pong();Bar::ping();":
s = f.pong()
if s != "Bar::pong();Foo::pong();Bar::ping();":
raise RuntimeError
pass
except:
raise RuntimeError," bad Foo::pong"
try:
s3 = fb.pong()
if s3 != "Bar::pong();Foo::pong();FooBar::ping();":
s = fb.pong()
if s != "Bar::pong();Foo::pong();FooBar::ping();":
raise RuntimeError
pass
except:
@ -52,3 +76,13 @@ except:
pass
if not protected:
raise RuntimeError,"Foo::ping is protected"
protected=1
try:
f.pang()
protected=0
except:
pass
if not protected:
raise RuntimeError,"FooBar::pang is protected"