1 // This is the STL wrapper for classlib/arrays.h from Borland's web site
2 // It has been modified to be compatible with vc++ (Paul Branann 5/7/98)
3 
4 #pragma once
5 
6 #ifdef _MSC_VER
7 #pragma warning(disable: 4786)
8 #endif
9 
10 // #include <vector.h>
11 // #include <algo.h>
12 #include <vector>
13 #include <algorithm>
14 #include <limits.h>
15 using namespace std;
16 
17 template <class T>
18 class TArrayAsVector : public vector<T> {
19 private:
20 	const unsigned int growable;
21 	typedef size_t size_type;
22 	typedef typename vector<T>::const_iterator const_iterator;
23 	const size_type lowerbound;
24 public:
25 	TArrayAsVector(size_type upper,
26 		size_type lower = 0,
27 		int delta = 0) :
28 	vector<T>( ),
29 		growable(delta),
30 		lowerbound(lower)
31 	{ vector<T>::reserve(upper-lower + 1);}
32 
33 	~TArrayAsVector( )
34 	{ // This call is unnecessary?  (Paul Brannan 5/7/98)
35 		// vector<T>::~vector( );
36 	}
37 
38 	int Add(const T& item)
39 	{ if(!growable && vector<T>::size( ) == vector<T>::capacity( ))
40 	return 0;
41 	else
42 		insert(vector<T>::end( ), item);
43 	return 1; }
44 
45 	int AddAt(const T& item, size_type index)
46 	{ if(!growable &&
47 	((vector<T>::size( ) == vector<T>::capacity( )) ||
48 	(ZeroBase(index > vector<T>::capacity( )) )))
49 	return 0;
50 	if(ZeroBase(index) > vector<T>::capacity( )) // out of bounds
51 	{ insert(vector<T>::end( ),
52 	ZeroBase(index) - vector<T>::size( ), T( ));
53 	insert(vector<T>::end( ), item); }
54 	else
55 	{ insert(vector<T>::begin( ) + ZeroBase(index), item); }
56 	return 1;
57 	}
58 
59 	size_type ArraySize( )
60 	{ return vector<T>::capacity( ); }
61 
62 	size_type BoundBase(size_type location) const
63 	{ if(location == UINT_MAX)
64 	return INT_MAX;
65 	else
66 		return location + lowerbound; }
67 	void Detach(size_type index)
68 	{ erase(vector<T>::begin( ) + ZeroBase(index)); }
69 
70 	void Detach(const T& item)
71 	{ Destroy(Find(item)); }
72 
73 	void Destroy(size_type index)
74 	{ erase(vector<T>::begin( ) + ZeroBase(index)); }
75 
76 	void Destroy(const T& item)
77 	{ Destroy(Find(item)); }
78 
79 	size_type Find(const T& item) const
80 	{ const_iterator location = find(vector<T>::begin( ),
81 	vector<T>::end( ), item);
82 	if(location != vector<T>::end( ))
83 		return BoundBase(size_type(location -
84 		vector<T>::begin( )));
85 	else
86 		return INT_MAX; }
87 
88 	size_type GetItemsInContainer( )
89 	{ return vector<T>::size( ); }
90 
91 	void Grow(size_type index)
92 	{ if( index < lowerbound )
93 	Reallocate(ArraySize( ) + (index -
94 	lowerbound));
95 	else if( index >= BoundBase(vector<T>::size( )))
96 		Reallocate(ZeroBase(index) ); }
97 
98 	int HasMember(const T& item)
99 	{ if(Find(item) != INT_MAX)
100 	return 1;
101 	else
102 		return 0; }
103 
104 	int IsEmpty( )
105 	{ return vector<T>::empty( ); }
106 
107 	int IsFull( )
108 	{ if(growable)
109 	return 0;
110 	if(vector<T>::size( ) == vector<T>::capacity( ))
111 		return 1;
112 	else
113 		return 0; }
114 
115 	size_type LowerBound( )
116 	{ return lowerbound; }
117 
118 	T& operator[] (size_type index)
119 	{ return vector<T>::
120 	operator[](ZeroBase(index)); }
121 
122 	const T& operator[] (size_type index) const
123 	{ return vector<T>::
124 	operator[](ZeroBase(index)); }
125 
126 	void Flush( )
127 	{
128 		vector<T>::clear();
129 	}
130 
131 	void Reallocate(size_type sz,
132 		size_type offset = 0)
133 	{ if(offset)
134 	insert(vector<T>::begin( ), offset, T( ));
135 	vector<T>::reserve(sz);
136 	erase(vector<T>::end( ) - offset, vector<T>::end( )); }
137 
138 	void RemoveEntry(size_type index)
139 	{ Detach(index); }
140 
141 	void SetData(size_type index, const T& item)
142 	{ (*this)[index] = item; }
143 
144 	size_type UpperBound( )
145 	{ return BoundBase(vector<T>::capacity( )) - 1; }
146 
147 	size_type ZeroBase(size_type index) const
148 	{ return index - lowerbound; }
149 
150 	// The assignment operator is not inherited (Paul Brannan 5/25/98)
151 	TArrayAsVector& operator=(const TArrayAsVector& v) {
152 		vector<T>::operator=(v);
153 		// should growable and lowerbound be copied as well?
154 		return *this;
155 	}
156 
157 };
158