diff options
author | Hemmo Nieminen <hemmo.nieminen@iki.fi> | 2018-03-01 00:25:12 +0200 |
---|---|---|
committer | Hemmo Nieminen <hemmo.nieminen@iki.fi> | 2018-03-01 01:06:51 +0200 |
commit | 7fb8e518b2666aa7eea0cf63b830884f2bfeb269 (patch) | |
tree | b60af0dfa3859f71108cdbe77d7750bd89028462 /mesonbuild/build.py | |
parent | b0446075ec8e7e3e1506610f03417da14d4a7b08 (diff) | |
download | meson-7fb8e518b2666aa7eea0cf63b830884f2bfeb269.zip meson-7fb8e518b2666aa7eea0cf63b830884f2bfeb269.tar.gz meson-7fb8e518b2666aa7eea0cf63b830884f2bfeb269.tar.bz2 |
Harmonize data pickling.
Try to be more consistent on using save() and load() methods to pickle
data.
Diffstat (limited to 'mesonbuild/build.py')
-rw-r--r-- | mesonbuild/build.py | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/mesonbuild/build.py b/mesonbuild/build.py index 6ed8843..9eb74e9 100644 --- a/mesonbuild/build.py +++ b/mesonbuild/build.py @@ -15,6 +15,7 @@ import copy, os, re from collections import OrderedDict import itertools, pathlib +import pickle from . import environment from . import dependencies @@ -1928,3 +1929,22 @@ def get_sources_string_names(sources): else: raise AssertionError('Unknown source type: {!r}'.format(s)) return names + +def load(build_dir): + filename = os.path.join(build_dir, 'meson-private', 'build.dat') + load_fail_msg = 'Build data file {!r} is corrupted. Try with a fresh build tree.'.format(filename) + nonexisting_fail_msg = 'No such build data file as "{!r}".'.format(filename) + try: + with open(filename, 'rb') as f: + obj = pickle.load(f) + except FileNotFoundError: + raise MesonException(nonexisting_fail_msg) + except pickle.UnpicklingError: + raise MesonException(load_fail_msg) + if not isinstance(obj, Build): + raise MesonException(load_fail_msg) + return obj + +def save(obj, filename): + with open(filename, 'wb') as f: + pickle.dump(obj, f) |