add test for the mangling extension #@ preproc.i

git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@5757 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
Marcelo Matus 2004-03-17 09:44:35 +00:00
commit 4267bda1a9
3 changed files with 47 additions and 11 deletions

View file

@ -204,4 +204,20 @@ This testcase tests operators for defines
#ifdef __cplusplus
#define %mangle(...) #@__VA_ARGS__
#define %mangle_str(...) ##@__VA_ARGS__
%define my_func(...)
inline const char* mangle ## #@__VA_ARGS__ () {
return %mangle_str(__VA_ARGS__);
}
%enddef
%inline {
my_func(class Int) ;
my_func(std::pair<double, std::complex< double > >*) ;
}
#endif

View file

@ -3,6 +3,16 @@
%include <complex.i>
#ifdef __cplusplus
%{
#include <algorithm>
#include <functional>
#include <numeric>
%}
%include <std_vector.i>
#if 1
%template(VectorStdCplx) std::vector<std::complex<double> >;
#endif
%inline
{
@ -15,8 +25,18 @@
{
return std::conj(a);
}
#if 1
std::vector<std::complex<double> > Copy_h(const std::vector<std::complex<double> >& a)
{
std::vector<std::complex<double> > b(a.size()/2);
std::copy(a.begin(), a.begin()+a.size()/2, b.begin());
return b;
}
#endif
}
#else
%inline

View file

@ -3,33 +3,33 @@
%module template_ns
%warnfilter(801) std::pair<int, int>; /* Ruby, wrong class name */
%warnfilter(801) std::pair<double, double>; /* Ruby, wrong class name */
%warnfilter(801) std::my_pair<int, int>; /* Ruby, wrong class name */
%warnfilter(801) std::my_pair<double, double>; /* Ruby, wrong class name */
%ignore std::pair::pair();
%ignore std::my_pair::my_pair();
%inline %{
namespace std
{
template <class _T1, class _T2>
struct pair {
struct my_pair {
typedef _T1 first_type;
typedef _T2 second_type;
_T1 first;
_T2 second;
pair() : first(_T1()), second(_T2()) {}
pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) {}
my_pair() : first(_T1()), second(_T2()) {}
my_pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) {}
template <class _U1, class _U2>
pair(const pair<_U1, _U2>& __p) : first(__p.first), second(__p.second) {}
my_pair(const my_pair<_U1, _U2>& __p) : first(__p.first), second(__p.second) {}
};
}
%}
// Add copy constructor
%extend std::pair {
%template(pair) pair<_T1,_T2>;
%extend std::my_pair {
%template(pair) my_pair<_T1,_T2>;
};
%template(pairii) std::pair<int,int>;
%template(pairdd) std::pair<double,double>;
%template(pairii) std::my_pair<int,int>;
%template(pairdd) std::my_pair<double,double>;