Each target language now has its own std_deque.i like the other STL wrappers.
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@8303 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
297c3e89ab
commit
eb433dbef1
10 changed files with 8 additions and 125 deletions
|
|
@ -1,120 +0,0 @@
|
|||
/* This file contains a generic definition of std::deque along with
|
||||
* some helper functions. Specific language modules should include
|
||||
* this file to generate wrappers.
|
||||
*/
|
||||
|
||||
%include <std_common.i>
|
||||
|
||||
%{
|
||||
#include <deque>
|
||||
#include <stdexcept>
|
||||
%}
|
||||
|
||||
|
||||
/* This macro defines all of the standard methods for a deque. This
|
||||
is defined as a macro to simplify the task of specialization. For
|
||||
example,
|
||||
|
||||
template<> class deque<int> {
|
||||
public:
|
||||
%std_deque_methods(int);
|
||||
};
|
||||
*/
|
||||
|
||||
%define %std_deque_methods(T)
|
||||
typedef T &reference;
|
||||
typedef const T& const_reference;
|
||||
|
||||
deque();
|
||||
deque(unsigned int size, const T& value=T());
|
||||
deque(const deque<T> &);
|
||||
~deque();
|
||||
|
||||
void assign(unsigned int n, const T& value);
|
||||
void swap(deque<T> &x);
|
||||
unsigned int size() const;
|
||||
unsigned int max_size() const;
|
||||
void resize(unsigned int n, T c = T());
|
||||
bool empty() const;
|
||||
const_reference front();
|
||||
const_reference back();
|
||||
void push_front(const T& x);
|
||||
void push_back(const T& x);
|
||||
void pop_front();
|
||||
void pop_back();
|
||||
void clear();
|
||||
|
||||
/* Some useful extensions */
|
||||
%extend {
|
||||
const_reference getitem(int i) throw (std::out_of_range) {
|
||||
int size = int(self->size());
|
||||
if (i<0) i += size;
|
||||
if (i>=0 && i<size)
|
||||
return (*self)[i];
|
||||
else
|
||||
throw std::out_of_range("deque index out of range");
|
||||
}
|
||||
void setitem(int i, const T& x) throw (std::out_of_range) {
|
||||
int size = int(self->size());
|
||||
if (i<0) i+= size;
|
||||
if (i>=0 && i<size)
|
||||
(*self)[i] = x;
|
||||
else
|
||||
throw std::out_of_range("deque index out of range");
|
||||
}
|
||||
void delitem(int i) throw (std::out_of_range) {
|
||||
int size = int(self->size());
|
||||
if (i<0) i+= size;
|
||||
if (i>=0 && i<size) {
|
||||
self->erase(self->begin()+i);
|
||||
} else {
|
||||
throw std::out_of_range("deque index out of range");
|
||||
}
|
||||
}
|
||||
std::deque<T> getslice(int i, int j) {
|
||||
int size = int(self->size());
|
||||
if (i<0) i = size+i;
|
||||
if (j<0) j = size+j;
|
||||
if (i<0) i = 0;
|
||||
if (j>size) j = size;
|
||||
std::deque<T > tmp(j-i);
|
||||
std::copy(self->begin()+i,self->begin()+j,tmp.begin());
|
||||
return tmp;
|
||||
}
|
||||
void setslice(int i, int j, const std::deque<T>& v) {
|
||||
int size = int(self->size());
|
||||
if (i<0) i = size+i;
|
||||
if (j<0) j = size+j;
|
||||
if (i<0) i = 0;
|
||||
if (j>size) j = size;
|
||||
if (int(v.size()) == j-i) {
|
||||
std::copy(v.begin(),v.end(),self->begin()+i);
|
||||
} else {
|
||||
self->erase(self->begin()+i,self->begin()+j);
|
||||
if (i+1 <= size)
|
||||
self->insert(self->begin()+i+1,v.begin(),v.end());
|
||||
else
|
||||
self->insert(self->end(),v.begin(),v.end());
|
||||
}
|
||||
}
|
||||
void delslice(int i, int j) {
|
||||
int size = int(self->size());
|
||||
if (i<0) i = size+i;
|
||||
if (j<0) j = size+j;
|
||||
if (i<0) i = 0;
|
||||
if (j>size) j = size;
|
||||
self->erase(self->begin()+i,self->begin()+j);
|
||||
}
|
||||
};
|
||||
|
||||
%enddef
|
||||
|
||||
namespace std {
|
||||
template<class T> class deque {
|
||||
public:
|
||||
%std_deque_methods(T);
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
|
||||
1
SWIG/Lib/csharp/std_deque.i
Normal file
1
SWIG/Lib/csharp/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
1
SWIG/Lib/guile/std_deque.i
Normal file
1
SWIG/Lib/guile/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
1
SWIG/Lib/java/std_deque.i
Normal file
1
SWIG/Lib/java/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
1
SWIG/Lib/lua/std_deque.i
Normal file
1
SWIG/Lib/lua/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
1
SWIG/Lib/mzscheme/std_deque.i
Normal file
1
SWIG/Lib/mzscheme/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
1
SWIG/Lib/perl5/std_deque.i
Normal file
1
SWIG/Lib/perl5/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
1
SWIG/Lib/php4/std_deque.i
Normal file
1
SWIG/Lib/php4/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
|
|
@ -1,5 +0,0 @@
|
|||
/* Default std_deque wrapper */
|
||||
%module std_deque
|
||||
|
||||
/* Include implementation specific code */
|
||||
%include <_std_deque.i>
|
||||
1
SWIG/Lib/tcl/std_deque.i
Normal file
1
SWIG/Lib/tcl/std_deque.i
Normal file
|
|
@ -0,0 +1 @@
|
|||
%include <std/_std_deque.i>
|
||||
Loading…
Add table
Add a link
Reference in a new issue