diff options
author | nechda <nechda@yandex-team.com> | 2024-11-02 11:20:12 +0300 |
---|---|---|
committer | nechda <nechda@yandex-team.com> | 2024-11-02 11:34:51 +0300 |
commit | c1e88b2643346523bc487519ca3615245fe372d2 (patch) | |
tree | 01fe58134bf0cf4c26e720c621c64685a69cc6e2 /build/scripts/wrapcc.py | |
parent | 73efac8142e4fb2b149797aadda491055f8fba02 (diff) | |
download | ydb-c1e88b2643346523bc487519ca3615245fe372d2.tar.gz |
Add python wrapper for clang
commit_hash:0ac8fe42fec35bd7fd78602530d909a5369b4e0b
Diffstat (limited to 'build/scripts/wrapcc.py')
-rw-r--r-- | build/scripts/wrapcc.py | 49 |
1 files changed, 9 insertions, 40 deletions
diff --git a/build/scripts/wrapcc.py b/build/scripts/wrapcc.py index 88a9e6a4fc..cb9c97b30e 100644 --- a/build/scripts/wrapcc.py +++ b/build/scripts/wrapcc.py @@ -1,45 +1,14 @@ -from __future__ import print_function - -import os -import sys -import time import subprocess +import sys -def need_retry(text): - return 'Stack dump' in text - - -def retry_inf(cmd): - while True: - try: - yield subprocess.check_output(cmd, stderr=subprocess.STDOUT), None - except subprocess.CalledProcessError as e: - yield e.output, e - - -def retry(cmd): - for n, (out, err) in enumerate(retry_inf(cmd)): - if out: - sys.stderr.write(out) - - if n > 5: - raise Exception('all retries failed') - elif need_retry(out): - time.sleep(1 + n) - elif err: - raise err - else: - return - +def fix(path: str): + flags = [] + return flags if __name__ == '__main__': - cmd = sys.argv[1:] - - if '-c' in cmd: - try: - retry(cmd) - except subprocess.CalledProcessError as e: - sys.exit(e.returncode) - else: - os.execv(cmd[0], cmd) + path = sys.argv[1] + args = sys.argv[2:] + cmd = args + fix(path) + rc = subprocess.call(cmd, shell=False, stderr=sys.stderr, stdout=sys.stdout) + sys.exit(rc) |