mirror of
https://github.com/KhronosGroup/SPIRV-Tools
synced 2025-01-12 01:20:05 +00:00
Support missing git in update_build_version.py (#5473)
Return False instead of raising an exception when running git commands fail, which allows the script to fallback to alternative options. Fixes #5469
This commit is contained in:
parent
fbf047cc8b
commit
6b1e609ef1
@ -62,9 +62,7 @@ def mkdir_p(directory):
|
||||
def command_output(cmd, directory):
|
||||
"""Runs a command in a directory and returns its standard output stream.
|
||||
|
||||
Captures the standard error stream.
|
||||
|
||||
Raises a RuntimeError if the command fails to launch or otherwise fails.
|
||||
Returns (False, None) if the command fails to launch or otherwise fails.
|
||||
"""
|
||||
try:
|
||||
# Set shell=True on Windows so that Chromium's git.bat can be found when
|
||||
@ -74,11 +72,10 @@ def command_output(cmd, directory):
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE,
|
||||
shell=os.name == 'nt')
|
||||
(stdout, stderr) = p.communicate()
|
||||
(stdout, _) = p.communicate()
|
||||
if p.returncode != 0:
|
||||
logging.error('Failed to run "{}" in "{}": {}'.format(cmd, directory, stderr.decode()))
|
||||
return False, None
|
||||
except Exception as e:
|
||||
logging.error('Failed to run "{}" in "{}": {}'.format(cmd, directory, str(e)))
|
||||
return False, None
|
||||
return p.returncode == 0, stdout
|
||||
|
||||
@ -127,7 +124,8 @@ def describe(repo_path):
|
||||
return output.rstrip().decode()
|
||||
|
||||
# This is the fallback case where git gives us no information,
|
||||
# e.g. because the source tree might not be in a git tree.
|
||||
# e.g. because the source tree might not be in a git tree or
|
||||
# git is not available on the system.
|
||||
# In this case, usually use a timestamp. However, to ensure
|
||||
# reproducible builds, allow the builder to override the wall
|
||||
# clock time with environment variable SOURCE_DATE_EPOCH
|
||||
|
Loading…
Reference in New Issue
Block a user