swig/Examples/test-suite/smart_pointer_member.i
Ian Lance Taylor 2970f53c21 Remove the -rename option in the Go language support. Do a much
better job of checking for name conflicts.  Ignore conflicting names
with a warning.  Adjust the testsuite accordingly.


git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@12135 626c5289-ae23-0410-ae9c-e8d60b6d4f22
2010-06-17 18:59:26 +00:00

56 lines
804 B
OpenEdge ABL

%module smart_pointer_member
%warnfilter(SWIGWARN_GO_NAME_CONFLICT); /* Ignoring 'foo' due to Go name ('Foo') conflict with 'Foo' */
%inline %{
class Foo {
public:
int x[4];
int y;
static const int z;
static const int ZZ = 3;
static int zx;
static int boo() { return 0;}
friend int foo(Foo* foo) { return 0;}
};
class Bar {
Foo *f;
public:
Bar(Foo *f) : f(f) { }
Foo *operator->() {
return f;
}
static int bua() { return 0;}
};
class CBar {
Foo *f;
public:
CBar(Foo *f) : f(f) { }
const Foo *operator->() {
return f;
}
};
int get_y(Bar *b)
{
return (*b)->y;
}
int get_z(Bar *b)
{
return (*b)->z;
}
%}
%{
const int Foo::z = 3;
int Foo::zx;
%}