server/src/eressea/lua/list.h

42 lines
952 B
C
Raw Normal View History

2003-12-14 11:02:29 +01:00
#ifndef LUA_LIST_H
#define LUA_LIST_H
namespace eressea {
template<class T, class N = T>
class listnode {
public:
static N next(N& node) { return node->next; }
static T value(N& node) { return node; }
2003-12-14 11:02:29 +01:00
};
template<class T, class N = T, class nodetype = listnode<T, N> >
class list {
public:
class iterator {
public:
iterator(const N& index) : m_index(index) {}
T operator*() { return nodetype::value(m_index); }
2003-12-14 11:02:29 +01:00
bool operator==(const iterator& iter) {
return iter.m_index==m_index;
}
iterator& operator++() {
if (m_index) m_index = nodetype::next(m_index);
return *this;
}
private:
N m_index;
2003-12-14 11:02:29 +01:00
};
typedef iterator const_iterator;
list<T, N, nodetype>(const N& clist) : m_clist(clist) {}
2003-12-14 11:02:29 +01:00
iterator begin() const { return iterator(m_clist); }
iterator end() const { return iterator(NULL); }
public:
N m_clist;
2003-12-14 11:02:29 +01:00
};
};
#endif