summaryrefslogtreecommitdiff
path: root/mesonbuild/coredata.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2018-05-15 23:27:42 +0300
committerJussi Pakkanen <jpakkane@gmail.com>2018-05-21 00:48:25 +0300
commite3be7f7021e6fe39509460f1187007ce4c2d1681 (patch)
tree90c412184a5540c69b1f8cf6f853e91d2ce48cd9 /mesonbuild/coredata.py
parent7e8c099387ffcdfbdc55e3ef550cf7e8ab0e848d (diff)
downloadmeson-e3be7f7021e6fe39509460f1187007ce4c2d1681.tar.gz
Write coredata transactionally. Closes #3511.
Diffstat (limited to 'mesonbuild/coredata.py')
-rw-r--r--mesonbuild/coredata.py11
1 files changed, 10 insertions, 1 deletions
diff --git a/mesonbuild/coredata.py b/mesonbuild/coredata.py
index a1dbac821..f3313f3f9 100644
--- a/mesonbuild/coredata.py
+++ b/mesonbuild/coredata.py
@@ -354,10 +354,19 @@ def load(build_dir):
def save(obj, build_dir):
filename = os.path.join(build_dir, 'meson-private', 'coredata.dat')
+ prev_filename = filename + '.prev'
+ tempfilename = filename + '~'
if obj.version != version:
raise MesonException('Fatal version mismatch corruption.')
- with open(filename, 'wb') as f:
+ if os.path.exists(filename):
+ import shutil
+ shutil.copyfile(filename, prev_filename)
+ with open(tempfilename, 'wb') as f:
pickle.dump(obj, f)
+ f.flush()
+ os.fsync(f.fileno())
+ os.replace(tempfilename, filename)
+ return filename
def get_builtin_options():
return list(builtin_options.keys())