d82e26b2fe5568f97ba8571c0e687d25d486f514
[oweals/cde.git] / cde / programs / nsgmls / NCVector.h
1 /* $XConsortium: NCVector.h /main/1 1996/07/29 16:58:13 cde-hp $ */
2 // Copyright (c) 1994, 1996 James Clark
3 // See the file COPYING for copying permission.
4
5 #ifndef NCVector_INCLUDED
6 #define NCVector_INCLUDED 1
7
8 #include <stddef.h>
9 #include "xnew.h"
10
11 // This offers a subset of the interface offered by the standard C++
12 // vector class as defined in the Jan 96 WP.
13 // Code in SP currently assumes that size_type is size_t.
14
15 #ifdef SP_NAMESPACE
16 namespace SP_NAMESPACE {
17 #endif
18
19 template<class T>
20 class NCVector {
21 public:
22   typedef size_t size_type;
23   typedef T *iterator;
24   typedef const T *const_iterator;
25   NCVector() : ptr_(0), size_(0), alloc_(0) { }
26   NCVector(size_t n) : ptr_(0), size_(0), alloc_(0) { append(n); }
27   ~NCVector();
28   void resize(size_t n) {
29     if (n < size_)
30       erase(ptr_ + n, ptr_ + size_);
31     else if (n > size_)
32       append(n - size_);
33   }
34   void swap(NCVector<T> &);
35   void clear() { erase(ptr_, ptr_ + size_); }
36   size_t size() const { return size_; }
37   T &operator[](size_t i) { return ptr_[i]; }
38   const T &operator[](size_t i) const { return ptr_[i]; }
39   iterator begin() { return ptr_; }
40   const_iterator begin() const { return ptr_; }
41   T &back() { return ptr_[size_ - 1]; }
42   const T &back() const { return ptr_[size_ - 1]; }
43   void reserve(size_t n) {  if (n > alloc_) reserve1(n); }
44   iterator erase(const_iterator, const_iterator);
45 private:
46   void append(size_t);
47   void reserve1(size_t);
48   
49   size_t size_;
50   T *ptr_;
51   size_t alloc_;                // allocated size
52 };
53
54 #ifdef SP_NAMESPACE
55 }
56 #endif
57
58 #endif /* not NCVector_INCLUDED */
59
60 #ifdef SP_DEFINE_TEMPLATES
61 #include "NCVector.C"
62 #endif