summaryrefslogtreecommitdiff
path: root/Examples/test-suite/cpp11_initializer_list.i
blob: 7e86cc025029aa2b8ffab0a91bb1e655cf0ed554 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
/* This testcase shows a few simple ways to deal with the new initializer_list
   introduced in C++11. */
%module cpp11_initializer_list

%warnfilter(SWIGWARN_TYPEMAP_INITIALIZER_LIST) B::B;
%ignore A::A(std::initializer_list<int>);
%ignore B::method;

%typemap(in) std::initializer_list<const char *> %{
  $1 = {"Ab", "Fab"};
%}

%runtime %{
#if __GNUC__ >= 9
/* warning: ‘new’ of initializer_list does not extend the lifetime of the underlying array [-Winit-list-lifetime] */
/* incorrect warning for C::C(std::initializer_list<const char *>) */
#pragma GCC diagnostic ignored "-Winit-list-lifetime"
#endif
%}

%inline %{
#include <initializer_list>
#include <string>

class A {
public:
  A(std::initializer_list<int>) {}
  A() {}
  A(double d) {}
};
class B {
public:
  B(std::initializer_list<int>, std::initializer_list<double>) {}
  B() {}
  void method(std::initializer_list<int> init) {}
};
class C {
  std::string joined;
public:
  C(std::initializer_list<const char *> init) {
    for (auto& val : init)
      joined = joined + val;
  }
  C() {}
  const char * get_joined_string() {
    return joined.c_str();
  }
};
%}