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 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
|
/* -----------------------------------------------------------------------------
* _std_common.i
*
* std::helpers for LUA
* ----------------------------------------------------------------------------- */
%include <std_except.i> // the general exceptions
/*
The basic idea here, is instead of trying to feed SWIG all the
horribly templated STL code, to give it a neatened version.
These %defines cover some of the more common methods
so the class declarations become just a set of %defines
*/
/* #define for basic container features
note: I allow front(), back() & pop_back() to throw exceptions
upon empty containers, rather than coredump
(as we haven't defined the methods, we can use %extend to add with
new features)
*/
%define %STD_CONTAINER_METHODS(CLASS,T)
public:
CLASS();
CLASS(const CLASS&);
unsigned int size() const;
unsigned int max_size() const;
bool empty() const;
void clear();
%extend { // the extra stuff which must be checked
T front()const throw (std::out_of_range){ // only read front & back
if (self->empty())
throw std::out_of_range("in "#CLASS"::front()");
return self->front();
}
T back()const throw (std::out_of_range){ // not write to them
if (self->empty())
throw std::out_of_range("in "#CLASS"::back()");
return self->back();
}
}
%enddef
/* push/pop for front/back
also note: front & back are read only methods, not used for writing
*/
%define %STD_FRONT_ACCESS_METHODS(CLASS,T)
public:
void push_front(const T& val);
%extend { // must check this
void pop_front() throw (std::out_of_range){
if (self->empty())
throw std::out_of_range("in "#CLASS"::pop_front()");
self->pop_back();
}
}
%enddef
%define %STD_BACK_ACCESS_METHODS(CLASS,T)
public:
void push_back(const T& val);
%extend { // must check this
void pop_back() throw (std::out_of_range){
if (self->empty())
throw std::out_of_range("in "#CLASS"::pop_back()");
self->pop_back();
}
}
%enddef
/*
Random access methods
*/
%define %STD_RANDOM_ACCESS_METHODS(CLASS,T)
%extend // this is a extra bit of SWIG code
{
// [] is replaced by __getitem__ & __setitem__
// simply throws a string, which causes a lua error
T __getitem__(unsigned int idx) throw (std::out_of_range){
if (idx>=self->size())
throw std::out_of_range("in "#CLASS"::__getitem__()");
return (*self)[idx];
}
void __setitem__(unsigned int idx,const T& val) throw (std::out_of_range){
if (idx>=self->size())
throw std::out_of_range("in "#CLASS"::__setitem__()");
(*self)[idx]=val;
}
};
%enddef
|