File: cdsList.hh

package info (click to toggle)
toshset 1.73-3
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 484 kB
  • ctags: 572
  • sloc: sh: 3,589; cpp: 2,938; ansic: 1,057; makefile: 190
file content (115 lines) | stat: -rw-r--r-- 2,425 bytes parent folder | download | duplicates (5)
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
   CDSList.h
   headers for my own List template class
   9/1/95 - CDS
*/

#ifndef __cdslist_hh__
#define __cdslist_hh__ 1

/* ostream is a typedef in the new standard, a class in the old, so forward
 * declarations are painful
 */
#include <iostream> 
using namespace std;

template<class T,int DefaultSize=10> 
class CDSList {
  int size_;  //number of elements used
  int asize;  //numer of elements allocated
  int blockSize;  //size for next allocation block
  T* data;
  //  enum { DefaultListSize = 100 };
public:

  CDSList (int s=0, int a=DefaultSize); 
  
  ~CDSList ();
  
  CDSList (const  CDSList<T,DefaultSize>&); //copy constructor

  CDSList &resize(const int s);

  CDSList  &operator= (const  CDSList<T,DefaultSize>&);
  const T  &operator[] (const int &index) const;
        T  &operator[] (const int &index);
  //  operator T*() { return data; } //convert to array

  const T  &append(const T& member);
  bool     contains(const T& member);
  void     remove(const int i);
  int      getIndex(const T& member);
  void     setBlockSize(const int);
  //  int      size() {return size_;}
  int      size() const {return size_;}
  //  template<class T2> 
//  friend ostream& operator<<(ostream& os, 
//			       const CDSList<T,DefaultSize>& v);

#ifdef TESTING
  static int test();
#endif
};

template <class T,int S> 
ostream& 
operator<<(ostream& os, const CDSList<T,S>& v);

//constructors

template<class T,int S>
CDSList<T,S>::CDSList(const int s,
		      const int a) :
  size_(s), asize(0), blockSize(a)
{
 while (size_ > asize) {
   asize += blockSize;
 }

 data = new T[asize];
} /* CDSList::CDSList */

template<class T,int S>
CDSList<T,S>::~CDSList()
{
 delete [] data;
}

template<class T,int S>
inline T&
CDSList<T,S>::operator[](const int &index)  //non-const version
{
#ifdef CHECKRANGE
 if (index+1>size_ || index<0) {
   cerr << "CDSList::operator[]: index out of range (" << index << ")\n";
   abort();
 }
#endif
 return (data[index]);
}

template<class T,int S>
inline const T& 
CDSList<T,S>::operator[](const int &index) const  //const version
{
#ifdef CHECKRANGE
 if (index+1>size_ || index<0) {
   cerr << "CDSList::operator[]: index out of range (" << index << ")\n";
   abort();
 }
#endif
 return (data[index]);
}

template<class T, int S>
const T& 
CDSList<T,S>::append(const T &member)
{
 resize(size_+1);
 data[size_-1] = member;
 return member;
}
 


#endif /*__cdslist_hh__*/