From a4fd2b74e268bbbb9e0dbb8698aac68c7ffbb893 Mon Sep 17 00:00:00 2001 From: Tor Egge Date: Mon, 23 Sep 2024 12:52:14 +0200 Subject: [PATCH] Add more information to exception stored in promise when visitation fails. --- searchlib/src/vespa/searchlib/docstore/filechunk.cpp | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/searchlib/src/vespa/searchlib/docstore/filechunk.cpp b/searchlib/src/vespa/searchlib/docstore/filechunk.cpp index f5e4dd7b1cd0..c55625de5d05 100644 --- a/searchlib/src/vespa/searchlib/docstore/filechunk.cpp +++ b/searchlib/src/vespa/searchlib/docstore/filechunk.cpp @@ -13,6 +13,7 @@ #include #include #include +#include #include #include @@ -334,13 +335,18 @@ FileChunk::appendTo(vespalib::Executor & executor, const IGetLid & db, IWriteDat std::promise promisedChunk; FutureChunk futureChunk(promisedChunk.get_future()); auto task = vespalib::makeLambdaTask([promise = std::move(promisedChunk), chunkId, this]() mutable { + const ChunkInfo & cInfo(_chunkInfo[chunkId]); try { - const ChunkInfo & cInfo(_chunkInfo[chunkId]); vespalib::DataBuffer whole(0ul, ALIGNMENT); FileRandRead::FSP keepAlive(_file->read(cInfo.getOffset(), whole, cInfo.getSize())); promise.set_value(std::make_unique(chunkId, whole.getData(), whole.getDataLen())); - } catch (...) { - promise.set_exception(std::current_exception()); + } catch (std::exception& e) { + promise.set_exception(std::make_exception_ptr( + std::runtime_error(std::string("File '") + _dataFileName + + "', offset " + std::to_string(cInfo.getOffset()) + + ", len " + std::to_string(cInfo.getSize()) + + ", chunkId " + std::to_string(chunkId) + + " : " + e.what()))); } }); executor.execute(CpuUsage::wrap(std::move(task), cpu_category));