swig/Examples/test-suite/pure_virtual.i
Olly Betts 7dfd9aae31 WARN_* constants are user visible, so keep existing WARN_PHP4_* for
backward compatibility, but add preferred forms WARN_PHP_* and use
these ourselves.

Rename Lib/php4 to Lib/php, Source/Modules/php4.cxx to Source/Modules/php.cxx.
 
Add typemaps for const reference so Examples/test-suite/apply_signed_char.i
works.


git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@10633 626c5289-ae23-0410-ae9c-e8d60b6d4f22
2008-07-03 00:09:56 +00:00

80 lines
1.5 KiB
OpenEdge ABL

/* SF Bug #445219, submitted by Krzysztof Kozminski
<kozminski@users.sf.net>.
Swig 1.3.6 gets confused by pure virtual destructors,
as in this file:
*/
%module(ruby_minherit="1") pure_virtual
%warnfilter(SWIGWARN_JAVA_MULTIPLE_INHERITANCE,
SWIGWARN_CSHARP_MULTIPLE_INHERITANCE,
SWIGWARN_PHP_MULTIPLE_INHERITANCE) E; /* C#, Java, PHP multiple inheritance */
%nodefaultctor C;
%nodefaultdtor C;
%nodefaultctor E;
%nodefaultdtor E;
%inline %{
class A {
public:
A() { };
virtual ~A() = 0;
virtual void something() = 0;
virtual void method() = 0;
};
class B : public A {
public:
B() {};
virtual ~B() { };
virtual void something() { };
virtual void method() { };
};
/* class C is abstract because it doesn't define all methods in A */
class C : public A {
public:
virtual ~C() { };
virtual void method() { };
}
;
/* class D is not abstract, it defines everything */
class D : public C {
public:
virtual ~D() { };
virtual void something() { };
}
;
/* Another abstract class */
class AA {
public:
virtual ~AA() { }
virtual void method2() = 0;
};
/* Multiple inheritance between two abstract classes */
class E : public C, public AA {
public:
virtual void something() { };
};
/* Fill in method from AA. This class should be constructable */
#ifdef SWIGCSHARP
%ignore F::method2(); // Work around for lack of multiple inheritance support - base AA is ignored.
#endif
class F : public E {
public:
virtual void method2() { }
};
%}
%{
A::~A() {}
%}