00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 namespace mongo {
00020
00021
00022
00023
00024
00025
00026
00027 template<typename T>
00028 class FastArray {
00029 public:
00030 FastArray( int capacity=10000 )
00031 : _capacity( capacity ) , _size(0) , _end(this,capacity) {
00032 _data = new T[capacity];
00033 }
00034
00035 ~FastArray() {
00036 delete[] _data;
00037 }
00038
00039 void clear() {
00040 _size = 0;
00041 }
00042
00043 T& operator[]( int x ) {
00044 assert( x >= 0 && x < _capacity );
00045 return _data[x];
00046 }
00047
00048 T& getNext() {
00049 return _data[_size++];
00050 }
00051
00052 void push_back( const T& t ) {
00053 assert( _size < _capacity );
00054 _data[_size++] = t;
00055 }
00056
00057 void sort( int (*comp)(const void *, const void *) ) {
00058 qsort( _data , _size , sizeof(T) , comp );
00059 }
00060
00061 int size() {
00062 return _size;
00063 }
00064
00065 bool hasSpace() {
00066 return _size < _capacity;
00067 }
00068 class iterator {
00069 public:
00070 iterator() {
00071 _it = 0;
00072 _pos = 0;
00073 }
00074
00075 iterator( FastArray * it , int pos=0 ) {
00076 _it = it;
00077 _pos = pos;
00078 }
00079
00080 bool operator==(const iterator& other ) const {
00081 return _pos == other._pos;
00082 }
00083
00084 bool operator!=(const iterator& other ) const {
00085 return _pos != other._pos;
00086 }
00087
00088 void operator++() {
00089 _pos++;
00090 }
00091
00092 T& operator*() {
00093 return _it->_data[_pos];
00094 }
00095
00096 string toString() const {
00097 stringstream ss;
00098 ss << _pos;
00099 return ss.str();
00100 }
00101 private:
00102 FastArray * _it;
00103 int _pos;
00104
00105 friend class FastArray;
00106 };
00107
00108
00109 iterator begin() {
00110 return iterator(this);
00111 }
00112
00113 iterator end() {
00114 _end._pos = _size;
00115 return _end;
00116 }
00117
00118
00119 private:
00120 int _capacity;
00121 int _size;
00122
00123 iterator _end;
00124
00125 T * _data;
00126 };
00127 }