From 50e28c480cda7b990999b0f215db7819344c3487 Mon Sep 17 00:00:00 2001 From: Ayoub Benaissa Date: Mon, 13 Jan 2025 10:59:23 +0100 Subject: [PATCH] fix(compiler): take edge cases into account --- .../include/concretelang/Common/Protocol.h | 21 +++++++++---------- 1 file changed, 10 insertions(+), 11 deletions(-) diff --git a/compilers/concrete-compiler/compiler/include/concretelang/Common/Protocol.h b/compilers/concrete-compiler/compiler/include/concretelang/Common/Protocol.h index c897be04f..6e12832ff 100644 --- a/compilers/concrete-compiler/compiler/include/concretelang/Common/Protocol.h +++ b/compilers/concrete-compiler/compiler/include/concretelang/Common/Protocol.h @@ -277,22 +277,21 @@ vectorToProtoPayload(const std::vector &input) { auto output = Message(); auto elmsPerBlob = capnp::MAX_TEXT_SIZE / sizeof(T); auto remainingElms = input.size() % elmsPerBlob; + auto nbCompleteBlobs = (input.size() / elmsPerBlob); auto nbBlobs = (input.size() / elmsPerBlob) + (remainingElms > 0); auto dataBuilder = output.asBuilder().initData(nbBlobs); // Process all but the last blob, which store as much as `Data` allow. - if (nbBlobs > 1) { - for (size_t blobIndex = 0; blobIndex < nbBlobs - 1; blobIndex++) { - auto blobPtr = input.data() + blobIndex * elmsPerBlob; - auto blobLen = elmsPerBlob * sizeof(T); - dataBuilder.set( - blobIndex, - capnp::Data::Reader(reinterpret_cast(blobPtr), - blobLen)); - } + for (size_t blobIndex = 0; blobIndex < nbCompleteBlobs; blobIndex++) { + auto blobPtr = input.data() + blobIndex * elmsPerBlob; + auto blobLen = elmsPerBlob * sizeof(T); + dataBuilder.set( + blobIndex, + capnp::Data::Reader(reinterpret_cast(blobPtr), + blobLen)); } - // Process the last blob which store the remainder. - if (nbBlobs > 0) { + if (remainingElms > 0) { + assert(nbCompleteBlobs == nbBlobs - 1); auto lastBlobIndex = nbBlobs - 1; auto lastBlobPtr = input.data() + lastBlobIndex * elmsPerBlob; auto lastBlobLen = remainingElms * sizeof(T);