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
|
#include "index.h"
#include "log.h"
#undef Trace
#define Trace() Trace_area("index." + mName.toLatin1())
Index::Index(const QString &storageRoot, const QString &name, Sink::Storage::AccessMode mode)
: mTransaction(Sink::Storage(storageRoot, name, mode).createTransaction(mode)),
mDb(mTransaction.openDatabase(name.toLatin1(), std::function<void(const Sink::Storage::Error &)>(), true)),
mName(name)
{
}
Index::Index(const QByteArray &name, Sink::Storage::Transaction &transaction)
: mDb(transaction.openDatabase(name, std::function<void(const Sink::Storage::Error &)>(), true)),
mName(name)
{
}
void Index::add(const QByteArray &key, const QByteArray &value)
{
mDb.write(key, value);
}
void Index::remove(const QByteArray &key, const QByteArray &value)
{
mDb.remove(key, value);
}
void Index::lookup(const QByteArray &key, const std::function<void(const QByteArray &value)> &resultHandler,
const std::function<void(const Error &error)> &errorHandler, bool matchSubStringKeys)
{
mDb.scan(key, [this, resultHandler](const QByteArray &key, const QByteArray &value) -> bool {
resultHandler(value);
return true;
},
[errorHandler](const Sink::Storage::Error &error) {
Warning() << "Error while retrieving value" << error.message;
errorHandler(Error(error.store, error.code, error.message));
},
matchSubStringKeys);
}
QByteArray Index::lookup(const QByteArray &key)
{
QByteArray result;
lookup(key,
[&result](const QByteArray &value) {
result = value;
},
[this](const Index::Error &error) {
Trace() << "Error while retrieving value" << error.message;
});
return result;
}
|