more smart_pointer fixes + cases

git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@6844 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
Marcelo Matus 2004-12-07 23:32:11 +00:00
commit d6760d4889
6 changed files with 87 additions and 26 deletions

View file

@ -11,9 +11,14 @@ b = CBase()
d = CDerived()
p = CPtr()
if b.bar() != p.bar():
raise RuntimeError
if d.foo() != p.foo():
raise RuntimeError
if b.hello() != p.hello():
raise RuntimeError

View file

@ -19,3 +19,12 @@ if b.x != f.x:
if b.z != f.z:
raise RuntimeError
if Foo.z == Bar.z:
raise RuntimeError

View file

@ -1,30 +1,51 @@
%module smart_pointer_extend
%inline %{
namespace hi
{
struct CBase
{
static int hello()
{
return 1;
}
};
class CBase
{
};
class CDerived : public CBase
{
};
class CDerived : public CBase
{
};
class CPtr
{
public:
CDerived* operator->(void) {return 0;};
};
class CPtr
{
public:
CDerived* operator->(void) {return 0;};
};
int get_hello(CPtr ptr)
{
return ptr->hello();
}
class CPtrConst
{
public:
CDerived* operator->(void) const {return 0;};
};
}
%}
%extend CBase {
%extend hi::CBase {
int foo(void) {return 1;};
int bar(void) {return 2;};
int boo(int i) {return i;};
}
%extend hi::CDerived {
int foo(void) {return 1;};
}
%extend CDerived {
int foo(void) {return 2;};
}
%extend Foo

View file

@ -9,6 +9,9 @@
int x[4];
int y;
static const int z;
static int boo() { return 0;}
};
class Bar {
@ -18,6 +21,17 @@
Foo *operator->() {
return f;
}
static int bua() { return 0;}
};
class CBar {
Foo *f;
public:
CBar(Foo *f) : f(f) { }
Foo *operator->() const {
return f;
}
};
int get_y(Bar *b)

View file

@ -250,7 +250,8 @@ class Allocate : public Dispatcher {
/* Grab methods used by smart pointers */
List *smart_pointer_methods(Node *cls, List *methods, int isconst) {
List *smart_pointer_methods(Node *cls, List *methods, int isconst,
String *classname=0) {
if (!methods) {
methods = NewList();
}
@ -266,7 +267,7 @@ class Allocate : public Dispatcher {
continue;
}
if (!isconst && (Strcmp(nodeType(c),"extend") == 0)) {
methods = smart_pointer_methods(c, methods, isconst);
methods = smart_pointer_methods(c, methods, isconst, Getattr(cls,"name"));
} else if (Strcmp(nodeType(c),"cdecl") == 0) {
if (!Getattr(c,"feature:ignore")) {
String *storage = Getattr(c,"storage");
@ -296,23 +297,30 @@ class Allocate : public Dispatcher {
if (!match) {
Node *cc = c;
while (cc) {
Node *cp = cc;
if (classname) {
Setattr(cp,"classname",classname);
}
Setattr(cp,"allocate:smartpointeraccess","1");
/* If constant, we have to be careful */
if (isconst) {
SwigType *decl = Getattr(cc,"decl");
SwigType *decl = Getattr(cp,"decl");
if (decl) {
if (SwigType_isfunction(decl)) { /* If method, we only add if it's a const method */
if (SwigType_isconst(decl)) {
Append(methods,cc);
Append(methods,cp);
}
} else {
Append(methods,cc);
Append(methods,cp);
}
} else {
Append(methods,cc);
Setattr(cp,"feature:immutable","1");
Append(methods,cp);
}
} else {
Append(methods,cc);
Append(methods,cp);
}
Delete(cp);
cc = Getattr(cc,"sym:nextSibling");
}
}

View file

@ -899,7 +899,8 @@ Language::functionHandler(Node *n) {
globalfunctionHandler(n);
} else {
String *storage = Getattr(n,"storage");
if (Cmp(storage,"static") == 0) {
if (Cmp(storage,"static") == 0 &&
!(SmartPointer && Getattr(n,"allocate:smartpointeraccess"))) {
staticmemberfunctionHandler(n);
} else if (Cmp(storage,"friend") == 0) {
globalfunctionHandler(n);
@ -1049,7 +1050,9 @@ Language::memberfunctionHandler(Node *n) {
String *fname = Swig_name_member(ClassPrefix, symname);
if (Extend && SmartPointer) {
Setattr(n,"classname",Getattr(CurrentClass,"allocate:smartpointerbase"));
if (!Getattr(n,"classname")) {
Setattr(n,"classname",Getattr(CurrentClass,"allocate:smartpointerbase"));
}
}
/* Transformation */
Swig_MethodToFunction(n,ClassType, Getattr(n,"template") ? 0 : Extend | SmartPointer);
@ -1133,14 +1136,15 @@ Language::variableHandler(Node *n) {
String *storage = Getattr(n,"storage");
Swig_save("variableHandler",n,"feature:immutable",NIL);
if (SmartPointer) {
/* If a smart-pointer and it's a constant access, we have to set immutable */
if (Getattr(CurrentClass,"allocate:smartpointerconst")) {
Setattr(n,"feature:immutable","1");
}
}
if ((Cmp(storage,"static") == 0)) {
if ((Cmp(storage,"static") == 0)
&& !(SmartPointer && Getattr(n,"allocate:smartpointeraccess"))) {
staticmembervariableHandler(n);
} else {
/* If a smart-pointer and it's a constant access, we have to set immutable */
membervariableHandler(n);
}
Swig_restore(n);