diff options
author | Christian Mollekopf <chrigi_1@fastmail.fm> | 2014-12-31 01:13:00 +0100 |
---|---|---|
committer | Christian Mollekopf <chrigi_1@fastmail.fm> | 2014-12-31 01:13:00 +0100 |
commit | 817bff01d15395206c1cc637d0c9ac0905007bf1 (patch) | |
tree | 918e6d992879f40b62273dc4cd9618f7bbd9b49c /common/pipeline.cpp | |
parent | 80149f959f254b1d52c0b5e883c4e76284f8abaf (diff) | |
download | sink-817bff01d15395206c1cc637d0c9ac0905007bf1.tar.gz sink-817bff01d15395206c1cc637d0c9ac0905007bf1.zip |
Moved entitybuffer construction code to EntityBuffer
Diffstat (limited to 'common/pipeline.cpp')
-rw-r--r-- | common/pipeline.cpp | 32 |
1 files changed, 8 insertions, 24 deletions
diff --git a/common/pipeline.cpp b/common/pipeline.cpp index dc6d389..04954ac 100644 --- a/common/pipeline.cpp +++ b/common/pipeline.cpp | |||
@@ -26,6 +26,7 @@ | |||
26 | #include <QDebug> | 26 | #include <QDebug> |
27 | #include "entity_generated.h" | 27 | #include "entity_generated.h" |
28 | #include "metadata_generated.h" | 28 | #include "metadata_generated.h" |
29 | #include "entitybuffer.h" | ||
29 | 30 | ||
30 | namespace Akonadi2 | 31 | namespace Akonadi2 |
31 | { | 32 | { |
@@ -76,33 +77,16 @@ void Pipeline::newEntity(const QByteArray &key, void *resourceBufferData, size_t | |||
76 | { | 77 | { |
77 | const qint64 newRevision = storage().maxRevision() + 1; | 78 | const qint64 newRevision = storage().maxRevision() + 1; |
78 | 79 | ||
79 | |||
80 | std::vector<uint8_t> metadataData; | ||
81 | //Add metadata buffer | 80 | //Add metadata buffer |
82 | { | 81 | flatbuffers::FlatBufferBuilder metadataFbb; |
83 | flatbuffers::FlatBufferBuilder metadataFbb; | 82 | auto metadataBuilder = Akonadi2::MetadataBuilder(metadataFbb); |
84 | auto metadataBuilder = Akonadi2::MetadataBuilder(metadataFbb); | 83 | metadataBuilder.add_revision(newRevision); |
85 | metadataBuilder.add_revision(newRevision); | 84 | auto metadataBuffer = metadataBuilder.Finish(); |
86 | auto metadataBuffer = metadataBuilder.Finish(); | 85 | Akonadi2::FinishMetadataBuffer(metadataFbb, metadataBuffer); |
87 | Akonadi2::FinishMetadataBuffer(metadataFbb, metadataBuffer); | ||
88 | metadataData.resize(metadataFbb.GetSize()); | ||
89 | std::copy_n(metadataFbb.GetBufferPointer(), metadataFbb.GetSize(), back_inserter(metadataData)); | ||
90 | } | ||
91 | |||
92 | 86 | ||
93 | flatbuffers::FlatBufferBuilder fbb; | 87 | flatbuffers::FlatBufferBuilder fbb; |
94 | auto metadata = fbb.CreateVector<uint8_t>(metadataData.data(), metadataData.size()); | 88 | EntityBuffer::assembleEntityBuffer(fbb, metadataFbb.GetBufferPointer(), metadataFbb.GetSize(), resourceBufferData, size, 0, 0); |
95 | auto resource = fbb.CreateVector<uint8_t>(static_cast<uint8_t*>(resourceBufferData), size); | 89 | |
96 | auto builder = Akonadi2::EntityBuilder(fbb); | ||
97 | builder.add_metadata(metadata); | ||
98 | builder.add_resource(resource); | ||
99 | //We don't have a local buffer yet | ||
100 | // builder.add_local(); | ||
101 | |||
102 | auto buffer = builder.Finish(); | ||
103 | Akonadi2::FinishEntityBuffer(fbb, buffer); | ||
104 | |||
105 | qDebug() << "writing new entity" << key; | ||
106 | storage().write(key.data(), key.size(), fbb.GetBufferPointer(), fbb.GetSize()); | 90 | storage().write(key.data(), key.size(), fbb.GetBufferPointer(), fbb.GetSize()); |
107 | storage().setMaxRevision(newRevision); | 91 | storage().setMaxRevision(newRevision); |
108 | 92 | ||