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
44
SWIG/Examples/test-suite/template_default2.i
Normal file
44
SWIG/Examples/test-suite/template_default2.i
Normal file
|
|
@ -0,0 +1,44 @@
|
|||
%module template_default2
|
||||
|
||||
%warnfilter(801) oss::traits; // Ruby, wrong class name
|
||||
|
||||
%inline %{
|
||||
namespace oss
|
||||
{
|
||||
enum Polarization { UnaryPolarization, BinaryPolarization };
|
||||
|
||||
template <Polarization P>
|
||||
struct Interface
|
||||
{
|
||||
};
|
||||
|
||||
struct traits
|
||||
{
|
||||
static const Polarization pmode = UnaryPolarization;
|
||||
};
|
||||
|
||||
template <class C,
|
||||
Polarization P = C::pmode,
|
||||
class Base = Interface<P> > // **** problem here *****
|
||||
struct Module : Base
|
||||
{
|
||||
};
|
||||
|
||||
}
|
||||
%}
|
||||
|
||||
namespace oss
|
||||
{
|
||||
%template(Interface_UP) Interface<UnaryPolarization>;
|
||||
|
||||
// This works
|
||||
%template(Module_UP1) Module<traits,
|
||||
UnaryPolarization,
|
||||
Interface<UnaryPolarization> >;
|
||||
|
||||
// These don't
|
||||
%template(Module_UP2) Module<traits, UnaryPolarization>;
|
||||
%template(Module_UP3) Module<traits>;
|
||||
}
|
||||
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue