fix: change subprocess.Popen calls to work on Linux too (#14689)

* fix: remove 'shell=True' when calling 'git diff'

Calling subprocess.Popen() with a list of args and shell=True causes
the args to be ignored, so ['git', 'diff', '--name-only', '--staged']
was turning into just 'git'. Instead of getting a list of changed
files, we got the --help message.

Two possible fixes: change it from a list to a single string, or remove
'shell=True'. The shell doesn't seem to be needed, so I chose that.

More reading: https://stackoverflow.com/questions/26417658/subprocess-call-arguments-ignored-when-using-shell-true-w-list

* fix: remove 'shell=True' when calling clang-format

Same problem / rationale as previous commit.

* fix: re-add shell=True for win; use different fix
This commit is contained in:
Charles Kerr 2018-09-20 01:57:21 -05:00 committed by Samuel Attard
parent 977e287cfa
commit 1b3fdb18e3

View file

@ -107,7 +107,7 @@ def run_clang_format_diff(args, file_name):
invocation = [args.clang_format_executable, file_name] invocation = [args.clang_format_executable, file_name]
try: try:
proc = subprocess.Popen( proc = subprocess.Popen(
invocation, ' '.join(invocation),
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
stderr=subprocess.PIPE, stderr=subprocess.PIPE,
universal_newlines=True, universal_newlines=True,
@ -253,7 +253,7 @@ def main():
parse_files = [] parse_files = []
if args.changed: if args.changed:
popen = subprocess.Popen( popen = subprocess.Popen(
["git", "diff", "--name-only", "--cached"], 'git diff --name-only --cached',
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
stderr=subprocess.STDOUT, stderr=subprocess.STDOUT,
shell=True shell=True