1 // 2 // std::map 3 // 4 5 %include <std_map.i> 6 7 8 %define %std_multimap_methods(mmap...) 9 %std_map_methods_common(mmap); 10 11 #ifdef SWIG_EXPORT_ITERATOR_METHODS 12 std::pair<iterator,iterator> equal_range(const key_type& x); 13 std::pair<const_iterator,const_iterator> equal_range(const key_type& x) const; 14 #endif 15 %enddef 16 17 // ------------------------------------------------------------------------ 18 // std::multimap 19 // 20 // const declarations are used to guess the intent of the function being 21 // exported; therefore, the following rationale is applied: 22 // 23 // -- f(std::multimap<T>), f(const std::multimap<T>&): 24 // the parameter being read-only, either a sequence or a 25 // previously wrapped std::multimap<T> can be passed. 26 // -- f(std::multimap<T>&), f(std::multimap<T>*): 27 // the parameter may be modified; therefore, only a wrapped std::multimap 28 // can be passed. 29 // -- std::multimap<T> f(), const std::multimap<T>& f(): 30 // the map is returned by copy; therefore, a sequence of T:s 31 // is returned which is most easily used in other functions 32 // -- std::multimap<T>& f(), std::multimap<T>* f(): 33 // the map is returned by reference; therefore, a wrapped std::multimap 34 // is returned 35 // -- const std::multimap<T>* f(), f(const std::multimap<T>*): 36 // for consistency, they expect and return a plain map pointer. 37 // ------------------------------------------------------------------------ 38 39 40 // exported class 41 42 43 namespace std { 44 template<class _Key, class _Tp, class _Compare = std::less<_Key >, 45 class _Alloc = allocator<std::pair<const _Key, _Tp > > > 46 class multimap { 47 public: 48 typedef size_t size_type; 49 typedef ptrdiff_t difference_type; 50 typedef _Key key_type; 51 typedef _Tp mapped_type; 52 typedef std::pair<const _Key, _Tp> value_type; 53 54 typedef value_type* pointer; 55 typedef const value_type* const_pointer; 56 typedef value_type& reference; 57 typedef const value_type& const_reference; 58 typedef _Alloc allocator_type; 59 60 %traits_swigtype(_Key); 61 %traits_swigtype(_Tp); 62 63 %fragment(SWIG_Traits_frag(std::pair< _Key, _Tp >), "header", 64 fragment=SWIG_Traits_frag(_Key), 65 fragment=SWIG_Traits_frag(_Tp), 66 fragment="StdPairTraits") { 67 namespace swig { 68 template <> struct traits<std::pair< _Key, _Tp > > { 69 typedef pointer_category category; 70 static const char* type_name() { 71 return "std::pair<" #_Key "," #_Tp " >"; 72 } 73 }; 74 } 75 } 76 77 %fragment(SWIG_Traits_frag(std::multimap<_Key, _Tp, _Compare, _Alloc >), "header", 78 fragment=SWIG_Traits_frag(std::pair<_Key, _Tp >), 79 fragment="StdMultimapTraits") { 80 namespace swig { 81 template <> struct traits<std::multimap<_Key, _Tp, _Compare, _Alloc > > { 82 typedef pointer_category category; 83 static const char* type_name() { 84 return "std::multimap<" #_Key "," #_Tp "," #_Compare "," #_Alloc " >"; 85 } 86 }; 87 } 88 } 89 90 %typemap_traits_ptr(SWIG_TYPECHECK_MULTIMAP, std::multimap<_Key, _Tp, _Compare, _Alloc >); 91 92 multimap( const _Compare& ); 93 94 #ifdef %swig_multimap_methods 95 // Add swig/language extra methods 96 %swig_multimap_methods(std::multimap<_Key, _Tp, _Compare, _Alloc >); 97 #endif 98 99 %std_multimap_methods(multimap); 100 }; 101 } 102