The great merge
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@4141 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
6fcc22a1f8
commit
516036631c
1508 changed files with 125983 additions and 44037 deletions
51
SWIG/Examples/test-suite/newobject1.i
Normal file
51
SWIG/Examples/test-suite/newobject1.i
Normal file
|
|
@ -0,0 +1,51 @@
|
|||
/**
|
||||
* The purpose of this test is to confirm that a language module
|
||||
* correctly handles the case when C++ class member functions (of both
|
||||
* the static and non-static persuasion) have been tagged with the
|
||||
* %newobject directive.
|
||||
*/
|
||||
|
||||
%module newobject1
|
||||
|
||||
%newobject Foo::makeFoo();
|
||||
%newobject Foo::makeMore();
|
||||
|
||||
%inline %{
|
||||
class Foo
|
||||
{
|
||||
private:
|
||||
Foo(const Foo&);
|
||||
Foo& operator=(const Foo&);
|
||||
private:
|
||||
static int m_fooCount;
|
||||
protected:
|
||||
Foo() {
|
||||
m_fooCount++;
|
||||
}
|
||||
public:
|
||||
// Factory function (static)
|
||||
static Foo *makeFoo() {
|
||||
return new Foo;
|
||||
}
|
||||
|
||||
// Factory function (regular)
|
||||
Foo *makeMore() {
|
||||
return new Foo;
|
||||
}
|
||||
|
||||
// Return the number of instances
|
||||
static int fooCount() {
|
||||
return m_fooCount;
|
||||
}
|
||||
|
||||
// Destructor
|
||||
~Foo() {
|
||||
m_fooCount--;
|
||||
}
|
||||
};
|
||||
%}
|
||||
|
||||
%{
|
||||
// Static member initialization (not wrapped)
|
||||
int Foo::m_fooCount = 0;
|
||||
%}
|
||||
Loading…
Add table
Add a link
Reference in a new issue