From 8e6661cce74dba6ed4572e84ab55c77a96a7d9e4 Mon Sep 17 00:00:00 2001 From: Jade Lovelace Date: Sat, 15 Jun 2024 16:39:14 -0700 Subject: [PATCH] store-api: fix/clarify capture lifetimes in copyPaths This seems to fix a use of stack after return. Change-Id: If690a6defb9a3225684685132cf78b227e271447 --- src/libstore/store-api.cc | 39 ++++++++++++++++++++++----------------- 1 file changed, 22 insertions(+), 17 deletions(-) diff --git a/src/libstore/store-api.cc b/src/libstore/store-api.cc index a10e5df0a..55083e834 100644 --- a/src/libstore/store-api.cc +++ b/src/libstore/store-api.cc @@ -1174,25 +1174,30 @@ std::map copyPaths( ValidPathInfo infoForDst = *info; infoForDst.path = storePathForDst; - auto source = sinkToSource([&](Sink & sink) { - // We can reasonably assume that the copy will happen whenever we - // read the path, so log something about that at that point - auto srcUri = srcStore.getUri(); - auto dstUri = dstStore.getUri(); - auto storePathS = srcStore.printStorePath(missingPath); - Activity act(*logger, lvlInfo, actCopyPath, - makeCopyPathMessage(srcUri, dstUri, storePathS), - {storePathS, srcUri, dstUri}); - PushActivity pact(act.id); + auto source = + sinkToSource([&srcStore, &dstStore, missingPath = missingPath, info = std::move(info)](Sink & sink) { + // We can reasonably assume that the copy will happen whenever we + // read the path, so log something about that at that point + auto srcUri = srcStore.getUri(); + auto dstUri = dstStore.getUri(); + auto storePathS = srcStore.printStorePath(missingPath); + Activity act( + *logger, + lvlInfo, + actCopyPath, + makeCopyPathMessage(srcUri, dstUri, storePathS), + {storePathS, srcUri, dstUri} + ); + PushActivity pact(act.id); - LambdaSink progressSink([&, total = 0ULL](std::string_view data) mutable { - total += data.size(); - act.progress(total, info->narSize); + LambdaSink progressSink([&, total = 0ULL](std::string_view data) mutable { + total += data.size(); + act.progress(total, info->narSize); + }); + TeeSink tee{sink, progressSink}; + + srcStore.narFromPath(missingPath, tee); }); - TeeSink tee { sink, progressSink }; - - srcStore.narFromPath(missingPath, tee); - }); pathsToCopy.push_back(std::pair{infoForDst, std::move(source)}); }