-
Notifications
You must be signed in to change notification settings - Fork 3
/
dnmarr.h
74 lines (59 loc) · 1.7 KB
/
dnmarr.h
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
//-< DNMARR.H >------------------------------------------------------*--------*
// POST++ Version 1.0 (c) 1998 GARRET * ? *
// (Persistent Object Storage) * /\| *
// * / \ *
// Created: 23-Jan-99 K.A. Knizhnik * / [] \ *
// Last update: 23-Jan-99 K.A. Knizhnik * GARRET *
//-------------------------------------------------------------------*--------*
// Transient (non-persistent) dynamc arra implementation
//-------------------------------------------------------------------*--------*
#ifndef __DNMARR_H__
#define __DNMARR_H__
BEGIN_POST_NAMESPACE
template<class T>
class POST_DLL_ENTRY dnm_array {
protected:
T* buf;
size_t buf_size;
size_t bp;
public:
size_t get_size() const { return bp; }
void set_size(size_t new_size) {
bp = new_size;
if (new_size > buf_size) {
if (new_size < buf_size*2) {
new_size = buf_size*2;
}
T* new_buf = new T[new_size];
memcpy(new_buf, buf, buf_size*sizeof(T));
delete[] buf;
buf = new_buf;
buf_size = new_size;
}
}
void push(T obj) {
int top = bp;
set_size(top+1);
buf[top] = obj;
}
bool is_empty() const { return bp == 0; }
T pop() {
assert(bp != 0);
return buf[--bp];
}
T& operator [](size_t index) {
assert(index < bp);
return buf[index];
}
dnm_array(size_t init_size = 256) {
bp = 0;
buf_size = init_size;
buf = new T[init_size];
}
~dnm_array() {
delete[] buf;
}
};
typedef dnm_array<object*> search_buffer;
END_POST_NAMESPACE
#endif