From 7ca36beb6f9eef3ce59f15e3b473d5136c79a84e Mon Sep 17 00:00:00 2001 From: Rune Morling Date: Fri, 13 Sep 2024 12:35:49 +0200 Subject: [PATCH] indexer: Write index atomically using `rename` This should help avoid build failures due to attempting to read the index while it is being rebuilt by vessel. Signed-off-by: Rune Morling --- source/vessel/indexer.d | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/source/vessel/indexer.d b/source/vessel/indexer.d index 9e4c120..d38338f 100644 --- a/source/vessel/indexer.d +++ b/source/vessel/indexer.d @@ -21,7 +21,7 @@ import moss.format.binary.payload; import moss.format.binary.payload.meta; import moss.format.binary.writer; import std.algorithm : multiSort; -import std.file : exists, mkdirRecurse; +import std.file : exists, mkdirRecurse, rename; import std.path : buildPath, dirName, relativePath; import vessel.collectiondb; import vibe.d; @@ -64,7 +64,8 @@ public final class Indexer auto records = collectionDB.volatileRecords(); records.multiSort!((a, b) => a.sourceID < b.sourceID, (a, b) => a.name < b.name); - auto fi = File(outputFilename, "wb"); + immutable string tmpIndexFile = outputFilename ~ ".tmp"; + auto fi = File(tmpIndexFile, "wb"); auto wr = new Writer(fi); wr.fileType = MossFileType.Repository; wr.compressionType = PayloadCompression.Zstd; @@ -104,6 +105,8 @@ public final class Indexer wr.addPayload(mp); } wr.close(); + /* rename is guaranteed to be atomic */ + tmpIndexFile.rename(outputFilename); } private: