2015-01-07 03:03:14 -05:00
|
|
|
import mem:*;
|
|
|
|
|
import util:*;
|
2015-03-16 14:01:15 -04:00
|
|
|
import io:*;
|
2014-06-30 01:57:50 -07:00
|
|
|
|
2014-07-23 02:23:21 -07:00
|
|
|
typedef template<T> vector (Destructable) {
|
2014-08-01 00:45:48 -07:00
|
|
|
|T*| data;
|
|
|
|
|
|int| size;
|
|
|
|
|
|int| available;
|
2014-07-06 23:42:25 -07:00
|
|
|
|
2014-08-01 00:45:48 -07:00
|
|
|
|vector<T>*| construct() {
|
2014-06-30 01:57:50 -07:00
|
|
|
size = 0;
|
|
|
|
|
available = 8;
|
|
|
|
|
data = new<T>(8);
|
|
|
|
|
return this;
|
|
|
|
|
}
|
|
|
|
|
|
2014-08-01 00:45:48 -07:00
|
|
|
|void| destruct() {
|
2014-07-28 01:52:15 -07:00
|
|
|
delete<T>(data);
|
2014-06-30 01:57:50 -07:00
|
|
|
}
|
|
|
|
|
|
2014-08-01 00:45:48 -07:00
|
|
|
|bool| resize(|int| newSize) {
|
|
|
|
|
|T*| newData = new<T>(newSize);
|
2014-06-30 01:57:50 -07:00
|
|
|
if (!newData)
|
|
|
|
|
return false;
|
2014-08-01 00:45:48 -07:00
|
|
|
for (|int| i = 0; i < lesser<int>(size, newSize); i++;)
|
2014-06-30 01:57:50 -07:00
|
|
|
newData[i] = data[i];
|
|
|
|
|
delete<T>(data, 0);
|
2015-03-11 01:58:10 -04:00
|
|
|
data = newData;
|
|
|
|
|
available = newSize;
|
2014-06-30 01:57:50 -07:00
|
|
|
return true;
|
|
|
|
|
}
|
2015-01-07 03:03:14 -05:00
|
|
|
|
2014-08-01 00:45:48 -07:00
|
|
|
|T| at(|int| index) {
|
2014-06-30 01:57:50 -07:00
|
|
|
return get(index);
|
|
|
|
|
}
|
2015-01-07 03:03:14 -05:00
|
|
|
|
2014-08-01 00:45:48 -07:00
|
|
|
|T| get(|int| index) {
|
2014-07-28 01:52:15 -07:00
|
|
|
if (index < 0 || index >= size) {
|
2015-03-16 14:01:15 -04:00
|
|
|
println("Vector access out of bounds! Retuning 0th element as sanest option");
|
|
|
|
|
print("Vector tried to access element: ");
|
|
|
|
|
println(index);
|
2014-07-28 01:52:15 -07:00
|
|
|
return data[0];
|
|
|
|
|
}
|
2014-06-30 01:57:50 -07:00
|
|
|
return data[index];
|
|
|
|
|
}
|
|
|
|
|
|
2015-03-11 01:58:10 -04:00
|
|
|
|T*| getBackingMemory() { return data; }
|
|
|
|
|
|
2014-08-01 00:45:48 -07:00
|
|
|
|void| set(|int| index, |T| dataIn) {
|
2014-07-03 01:52:44 -07:00
|
|
|
if (index < 0 || index >= size)
|
2014-06-30 01:57:50 -07:00
|
|
|
return;
|
|
|
|
|
data[index] = dataIn;
|
|
|
|
|
}
|
2014-08-01 00:45:48 -07:00
|
|
|
|void| addEnd(|T| dataIn) {
|
2015-03-11 01:58:10 -04:00
|
|
|
size++;
|
|
|
|
|
if (size >= available)
|
2014-06-30 01:57:50 -07:00
|
|
|
resize(size*2);
|
2014-07-28 01:52:15 -07:00
|
|
|
data[size-1] = dataIn;
|
2014-06-30 01:57:50 -07:00
|
|
|
}
|
|
|
|
|
};
|