summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Engestrom <[email protected]>2017-10-25 14:04:35 +0100
committerEric Engestrom <[email protected]>2017-10-27 13:38:37 +0100
commit7088622e5fb506b64c906b673a9af0feb9a5ba14 (patch)
treebcf6b8c47f47e9ebe43a7781e4016c2817127d04
parenta41e2e9cf5f865f21e32cac2ed2e25dd21a05119 (diff)
buildsys: move file regeneration logic to the script itself
Signed-off-by: Eric Engestrom <[email protected]> Reviewed-by: Jordan Justen <[email protected]> Reviewed-by: Dylan Baker <[email protected]>
-rwxr-xr-xbin/git_sha1_gen.py13
-rw-r--r--src/Makefile.am15
-rw-r--r--src/SConscript22
-rw-r--r--src/mesa/Android.libmesa_git_sha1.mk4
4 files changed, 24 insertions, 30 deletions
diff --git a/bin/git_sha1_gen.py b/bin/git_sha1_gen.py
index c75dba101ac..7b9267b59e9 100755
--- a/bin/git_sha1_gen.py
+++ b/bin/git_sha1_gen.py
@@ -6,6 +6,7 @@ The output of this script goes to stdout.
"""
+import argparse
import os
import os.path
import subprocess
@@ -27,10 +28,20 @@ def get_git_sha1():
git_sha1 = ''
return git_sha1
+parser = argparse.ArgumentParser()
+parser.add_argument('--output', help='File to write the #define in',
+ required=True)
+args = parser.parse_args()
git_sha1 = os.environ.get('MESA_GIT_SHA1_OVERRIDE', get_git_sha1())[:10]
if git_sha1:
git_sha1_h_in_path = os.path.join(os.path.dirname(sys.argv[0]),
'..', 'src', 'git_sha1.h.in')
with open(git_sha1_h_in_path , 'r') as git_sha1_h_in:
- sys.stdout.write(git_sha1_h_in.read().replace('@VCS_TAG@', git_sha1))
+ 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)
diff --git a/src/Makefile.am b/src/Makefile.am
index 5ef2d4f55ea..1de4fca6a12 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -19,17 +19,10 @@
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
# IN THE SOFTWARE.
-.PHONY: git_sha1.h.tmp
-git_sha1.h.tmp:
- @$(PYTHON2) $(top_srcdir)/bin/git_sha1_gen.py > $@
-
-git_sha1.h: git_sha1.h.tmp
- @echo "updating git_sha1.h"
- @if ! cmp -s git_sha1.h.tmp git_sha1.h; then \
- mv git_sha1.h.tmp git_sha1.h ;\
- else \
- rm git_sha1.h.tmp ;\
- fi
+.PHONY: git_sha1.h
+git_sha1.h: $(top_srcdir)/src/git_sha1.h.in
+ @echo "updating $@"
+ @$(PYTHON2) $(top_srcdir)/bin/git_sha1_gen.py --output $@
BUILT_SOURCES = git_sha1.h
CLEANFILES = $(BUILT_SOURCES)
diff --git a/src/SConscript b/src/SConscript
index a277e8b7925..95ea061c4bb 100644
--- a/src/SConscript
+++ b/src/SConscript
@@ -24,22 +24,12 @@ def write_git_sha1_h_file(filename):
to retrieve the git hashid and write the header file. An empty file
will be created if anything goes wrong."""
- tempfile = "git_sha1.h.tmp"
- with open(tempfile, "w") as f:
- args = [ python_cmd, Dir('#').abspath + '/bin/git_sha1_gen.py' ]
- try:
- subprocess.Popen(args, stdout=f).wait()
- except:
- print("Warning: exception in write_git_sha1_h_file()")
- return
-
- if not os.path.exists(filename) or not filecmp.cmp(tempfile, filename):
- # The filename does not exist or it's different from the new file,
- # so replace old file with new.
- if os.path.exists(filename):
- os.remove(filename)
- os.rename(tempfile, filename)
- return
+ args = [ python_cmd, Dir('#').abspath + '/bin/git_sha1_gen.py', '--output', filename ]
+ try:
+ subprocess.call(args)
+ except:
+ print("Warning: exception in write_git_sha1_h_file()")
+ return
# Create the git_sha1.h header file
diff --git a/src/mesa/Android.libmesa_git_sha1.mk b/src/mesa/Android.libmesa_git_sha1.mk
index ddb30c428af..d27923074dd 100644
--- a/src/mesa/Android.libmesa_git_sha1.mk
+++ b/src/mesa/Android.libmesa_git_sha1.mk
@@ -43,10 +43,10 @@ $(intermediates)/dummy.c:
LOCAL_GENERATED_SOURCES += $(addprefix $(intermediates)/, git_sha1.h)
-$(intermediates)/git_sha1.h: $(wildcard $(MESA_TOP)/.git/logs/HEAD)
+$(intermediates)/git_sha1.h: $(MESA_TOP)/src/git_sha1.h.in $(wildcard $(MESA_TOP)/.git/logs/HEAD)
@mkdir -p $(dir $@)
@echo "GIT-SHA1: $(PRIVATE_MODULE) <= git"
- $(hide) $(MESA_PYTHON2) $(MESA_TOP)/bin/git_sha1_gen.py > $@
+ $(hide) $(MESA_PYTHON2) $(MESA_TOP)/bin/git_sha1_gen.py --output $@
LOCAL_EXPORT_C_INCLUDE_DIRS := $(intermediates)