add intermediary_classname.i for testing changing the intermediary classname from default (Java/C#)
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk/SWIG@8025 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
580badb099
commit
1e9ff45c66
2 changed files with 64 additions and 0 deletions
|
|
@ -155,6 +155,7 @@ CPP_TEST_CASES += \
|
|||
inherit_same_name \
|
||||
inherit_void_arg \
|
||||
inline_initializer \
|
||||
intermediary_classname \
|
||||
kind \
|
||||
langobj \
|
||||
li_attribute \
|
||||
|
|
|
|||
63
Examples/test-suite/intermediary_classname.i
Normal file
63
Examples/test-suite/intermediary_classname.i
Normal file
|
|
@ -0,0 +1,63 @@
|
|||
|
||||
// This test is to check the intermediary class name can be changed (C# and Java only use intermediary classes at time of writing)
|
||||
%module(directors="1", jniclassname="intermediary_classname", imclassname="intermediary_classname") "intermediary_classname"
|
||||
|
||||
// change the access to the intermediary class for testing purposes
|
||||
%pragma(java) jniclassclassmodifiers="public class";
|
||||
%pragma(csharp) imclassclassmodifiers="public class";
|
||||
|
||||
%feature("director") Base;
|
||||
%feature("director") Derived;
|
||||
|
||||
%inline %{
|
||||
|
||||
template<class T> T maximum(const T a, const T b) { return a>b ? a : b; }
|
||||
|
||||
template<class T> class vector {
|
||||
T *v;
|
||||
int sz;
|
||||
public:
|
||||
vector(int _sz) {
|
||||
v = new T[_sz];
|
||||
sz = _sz;
|
||||
}
|
||||
T &get(int index) {
|
||||
return v[index];
|
||||
}
|
||||
void set(int index, T &val) {
|
||||
v[index] = val;
|
||||
}
|
||||
void testconst(const T x) { }
|
||||
};
|
||||
|
||||
class Base {
|
||||
public:
|
||||
Base() : mVectInt(0) {}
|
||||
Base(Base *b) : mVectInt(0) {}
|
||||
virtual ~Base() {}
|
||||
virtual Base& m1(Base &b) { return b; }
|
||||
virtual Base* m2(Base *b) { return b; }
|
||||
// virtual Base m3(Base b) { return b; }
|
||||
vector<int> mVectInt;
|
||||
int mInt;
|
||||
enum en { en1, en2 };
|
||||
en enummethod(en e) { return e; }
|
||||
};
|
||||
class Derived : public Base {
|
||||
public:
|
||||
Derived(Base *b) : Base(b) {}
|
||||
virtual Base& m1(Base &b) { return b; }
|
||||
virtual Base* m2(Base *b) { return b; }
|
||||
// virtual Base m3(Base b) { return b; }
|
||||
void throwspec() throw (int, Base) {}
|
||||
};
|
||||
%}
|
||||
|
||||
%template(maxint) maximum<int>;
|
||||
%template(maxdouble) maximum<double>;
|
||||
%template(vecint) vector<int>;
|
||||
%template(vecdouble) vector<double>;
|
||||
%template(maxintp) maximum<int (*)[10]>;
|
||||
%template(vecintp) vector<int (*)[10]>;
|
||||
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue