adding more cases

git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@7673 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
Marcelo Matus 2005-10-17 13:48:02 +00:00
commit ce0cbfcbb4
5 changed files with 85 additions and 0 deletions

View file

@ -0,0 +1,47 @@
struct B {
int x;
B(const int x) : x(x) {}
B& get_me()
{
return *this;
}
B& operator+=(const B& a) {
x += a.x;
return *this;
}
};
namespace test {
struct A {
int x;
A(const int x) : x(x) {}
A& get_me()
{
return *this;
}
A operator+=(const A& a) {
x += a.x;
return *this;
}
};
class Foo {
public:
Foo(): _a(new A(5)), _n(new long) {}
~Foo() { delete _a; delete _n; _a = NULL; _n = NULL; }
A & AsA() const { return *_a; }
long& AsLong() const { return *_n; }
private:
A *_a;
long *_n;
};
}

View file

@ -0,0 +1,18 @@
%module iadd
%include attribute.i
%{
#include "iadd.h"
%}
class Foo;
%attribute_ref(test::Foo, test::A& , AsA);
%attribute_ref(test::Foo, long, AsLong);
%typemap(out) B & B::operator+= "hello";
%include "iadd.h"

View file

@ -0,0 +1,5 @@
import iadd
f = iadd.Foo()
f.AsA += f.AsA

View file

@ -1,4 +1,7 @@
%module inplaceadd
%{
#include <iostream>
%}
%inline %{
@ -8,6 +11,8 @@
A(int v): val(v)
{
int a = 2;
a += (a +=1 ) = 5;
}
A& operator+=(int v)
@ -16,6 +21,12 @@
return *this;
}
A& operator+=(const A& a)
{
val += a.val;
return *this;
}
A& operator-=(int v)
{
val -= v;

View file

@ -16,3 +16,7 @@ a *= 2
if a.val != 14:
raise RuntimeError
a += a
if a.val != 28:
raise RuntimeError