summaryrefslogtreecommitdiffstats
path: root/common/pipeline.cpp
diff options
context:
space:
mode:
authorChristian Mollekopf <chrigi_1@fastmail.fm>2014-12-31 01:13:00 +0100
committerChristian Mollekopf <chrigi_1@fastmail.fm>2014-12-31 01:13:00 +0100
commit817bff01d15395206c1cc637d0c9ac0905007bf1 (patch)
tree918e6d992879f40b62273dc4cd9618f7bbd9b49c /common/pipeline.cpp
parent80149f959f254b1d52c0b5e883c4e76284f8abaf (diff)
downloadsink-817bff01d15395206c1cc637d0c9ac0905007bf1.tar.gz
sink-817bff01d15395206c1cc637d0c9ac0905007bf1.zip
Moved entitybuffer construction code to EntityBuffer
Diffstat (limited to 'common/pipeline.cpp')
-rw-r--r--common/pipeline.cpp32
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
30namespace Akonadi2 31namespace 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