diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2018-05-15 23:27:42 +0300 |
---|---|---|
committer | Jussi Pakkanen <jpakkane@gmail.com> | 2018-05-21 00:48:25 +0300 |
commit | e3be7f7021e6fe39509460f1187007ce4c2d1681 (patch) | |
tree | 90c412184a5540c69b1f8cf6f853e91d2ce48cd9 /mesonbuild/coredata.py | |
parent | 7e8c099387ffcdfbdc55e3ef550cf7e8ab0e848d (diff) | |
download | meson-e3be7f7021e6fe39509460f1187007ce4c2d1681.tar.gz |
Write coredata transactionally. Closes #3511.
Diffstat (limited to 'mesonbuild/coredata.py')
-rw-r--r-- | mesonbuild/coredata.py | 11 |
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()) |