-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOpenQueue.cpp
50 lines (40 loc) · 1.11 KB
/
OpenQueue.cpp
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
#include "OpenQueue.hpp"
#include <cassert>
#include <string>
/* instantiation point */
template class OpenQueue<std::string>;
template <typename T>
OpenQueue<T>::OpenQueue(const char *file) {
assert((queue = diskqueue_open(file)));
}
template <typename T>
OpenQueue<T>::~OpenQueue() {
diskqueue_close(queue);
}
template <typename T>
uint32_t OpenQueue<T>::max_elements() const noexcept {
return diskqueue_max_elements();
}
template <typename T>
bool OpenQueue<T>::empty() const noexcept {
return diskqueue_empty(queue);
}
template <>
bool OpenQueue<std::string>::push(const std::string &o) {
UserData data{(void *)o.c_str(), (uint32_t)o.length()};
return diskqueue_push(queue, data);
}
template <>
std::string OpenQueue<std::string>::front() const {
UserData data{diskqueue_front(queue)};
std::string ret{(const char *)data.data, (typename std::string::size_type)data.size};
free(data.data);
return ret;
}
template <>
std::string OpenQueue<std::string>::pop() {
UserData data{diskqueue_pop(queue)};
std::string ret{(const char *)data.data, (typename std::string::size_type)data.size};
free(data.data);
return ret;
}