[Mesa-dev] [PATCH mesa 1/3] bin: split `write_if_different()` out
Eric Engestrom
eric.engestrom at intel.com
Tue Aug 14 17:24:11 UTC 2018
Signed-off-by: Eric Engestrom <eric.engestrom at intel.com>
---
bin/git_sha1_gen.py | 21 ++++++++++++++-------
1 file changed, 14 insertions(+), 7 deletions(-)
diff --git a/bin/git_sha1_gen.py b/bin/git_sha1_gen.py
index 68a87e72ec563ce6298f..bc0279ccef16d42bb88d 100755
--- a/bin/git_sha1_gen.py
+++ b/bin/git_sha1_gen.py
@@ -28,6 +28,18 @@ def get_git_sha1():
git_sha1 = ''
return git_sha1
+def write_if_different(contents):
+ """
+ Avoid touching the output file if it doesn't need modifications
+ Useful to avoid triggering revuilds when nothing has changed.
+ """
+ if os.path.isfile(args.output):
+ with open(args.output, 'r') as file:
+ if file.read() == contents:
+ return
+ with open(args.output, 'w') as file:
+ file.write(contents)
+
parser = argparse.ArgumentParser()
parser.add_argument('--output', help='File to write the #define in',
required=True)
@@ -39,11 +51,6 @@ def get_git_sha1():
'..', 'src', 'git_sha1.h.in')
with open(git_sha1_h_in_path , 'r') as git_sha1_h_in:
new_sha1 = git_sha1_h_in.read().replace('@VCS_TAG@', git_sha1)
- if os.path.isfile(args.output):
- with open(args.output, 'r') as git_sha1_h:
- if git_sha1_h.read() == new_sha1:
- quit()
- with open(args.output, 'w') as git_sha1_h:
- git_sha1_h.write(new_sha1)
+ write_if_different(new_sha1)
else:
- open(args.output, 'w').close()
+ write_if_different('')
--
Cheers,
Eric
More information about the mesa-dev
mailing list