sentinel-stack.icc
Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038 namespace Gecode { namespace Support {
00039
00052 template<class T>
00053 class SentinelStack {
00054 private:
00055 #ifndef NDEBUG
00056 unsigned int size;
00057 T* bos;
00058 #endif
00059 const T sentinel;
00060 T* tos;
00061 public:
00063 SentinelStack(T* p, T s, int n);
00065 bool empty(void) const;
00067 T top(void) const;
00069 T last(void) const;
00071 T pop(void);
00073 void push(T x);
00074 };
00075
00076 template<class T>
00077 forceinline
00078 SentinelStack<T>::SentinelStack(T* p, T s, int n)
00079 :
00080 #ifndef NDEBUG
00081 size(n), bos(p),
00082 #endif
00083 sentinel(s), tos(p) {
00084 (void) n;
00085 *(tos++) = sentinel;
00086 }
00087 template<class T>
00088 forceinline bool
00089 SentinelStack<T>::empty(void) const {
00090 return *(tos-1) == sentinel;
00091 }
00092 template<class T>
00093 forceinline T
00094 SentinelStack<T>::top(void) const {
00095 assert(*(tos-1) != sentinel);
00096 return *(tos-1);
00097 }
00098 template<class T>
00099 forceinline T
00100 SentinelStack<T>::last(void) const {
00101 return *tos;
00102 }
00103 template<class T>
00104 forceinline T
00105 SentinelStack<T>::pop(void) {
00106 #ifndef NDEBUG
00107 assert(tos-bos > 1);
00108 #endif
00109 return *(--tos);
00110 }
00111 template<class T>
00112 forceinline void
00113 SentinelStack<T>::push(T x) {
00114 assert(x != sentinel);
00115 #ifndef NDEBUG
00116 assert(tos-bos < size+1);
00117 #endif
00118 *(tos++) = x;
00119 }
00120
00121 }}
00122
00134 #define GECODE_AUTOSTACK(T,S,X,N) \
00135 int __GECODE__AS__ ## X ## __LINE__ ## n = (N); \
00136 GECODE_AUTOARRAY(T,__GECODE__AS__ ## X ## __LINE__,(__GECODE__AS__ ## X ## __LINE__ ## n) + 1); \
00137 Gecode::Support::SentinelStack<T> X(__GECODE__AS__ ## X ## __LINE__,(S),__GECODE__AS__ ## X ## __LINE__ ## n);
00138