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:
parent
81ae8b5e68
commit
4267bda1a9
3 changed files with 47 additions and 11 deletions
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -3,6 +3,16 @@
|
||||||
%include <complex.i>
|
%include <complex.i>
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
%{
|
||||||
|
#include <algorithm>
|
||||||
|
#include <functional>
|
||||||
|
#include <numeric>
|
||||||
|
%}
|
||||||
|
%include <std_vector.i>
|
||||||
|
|
||||||
|
#if 1
|
||||||
|
%template(VectorStdCplx) std::vector<std::complex<double> >;
|
||||||
|
#endif
|
||||||
|
|
||||||
%inline
|
%inline
|
||||||
{
|
{
|
||||||
|
|
@ -15,8 +25,18 @@
|
||||||
{
|
{
|
||||||
return std::conj(a);
|
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
|
#else
|
||||||
|
|
||||||
%inline
|
%inline
|
||||||
|
|
|
||||||
|
|
@ -3,33 +3,33 @@
|
||||||
|
|
||||||
%module template_ns
|
%module template_ns
|
||||||
|
|
||||||
%warnfilter(801) std::pair<int, int>; /* Ruby, wrong class name */
|
%warnfilter(801) std::my_pair<int, int>; /* Ruby, wrong class name */
|
||||||
%warnfilter(801) std::pair<double, double>; /* 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 %{
|
%inline %{
|
||||||
namespace std
|
namespace std
|
||||||
{
|
{
|
||||||
template <class _T1, class _T2>
|
template <class _T1, class _T2>
|
||||||
struct pair {
|
struct my_pair {
|
||||||
typedef _T1 first_type;
|
typedef _T1 first_type;
|
||||||
typedef _T2 second_type;
|
typedef _T2 second_type;
|
||||||
|
|
||||||
_T1 first;
|
_T1 first;
|
||||||
_T2 second;
|
_T2 second;
|
||||||
pair() : first(_T1()), second(_T2()) {}
|
my_pair() : first(_T1()), second(_T2()) {}
|
||||||
pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) {}
|
my_pair(const _T1& __a, const _T2& __b) : first(__a), second(__b) {}
|
||||||
template <class _U1, class _U2>
|
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
|
// Add copy constructor
|
||||||
%extend std::pair {
|
%extend std::my_pair {
|
||||||
%template(pair) pair<_T1,_T2>;
|
%template(pair) my_pair<_T1,_T2>;
|
||||||
};
|
};
|
||||||
|
|
||||||
%template(pairii) std::pair<int,int>;
|
%template(pairii) std::my_pair<int,int>;
|
||||||
%template(pairdd) std::pair<double,double>;
|
%template(pairdd) std::my_pair<double,double>;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue