fix(bin/linja): use Popen.communicate instead of Popen.wait

Popen.wait() can cause deadlock.

Reference:
https://docs.python.org/2/library/subprocess.html#subprocess.Popen.wait
This commit is contained in:
Soonho Kong 2014-09-30 14:21:02 -07:00
parent 562cc2c8f3
commit 5deb6e10db

View file

@ -336,10 +336,8 @@ def call_ninja(args):
proc_out = subprocess.PIPE proc_out = subprocess.PIPE
proc_err = subprocess.PIPE proc_err = subprocess.PIPE
proc = subprocess.Popen([g_ninja_path] + targets, stdout=proc_out, stderr=proc_err) proc = subprocess.Popen([g_ninja_path] + targets, stdout=proc_out, stderr=proc_err)
proc.wait()
if args.flycheck:
(out, err) = proc.communicate() (out, err) = proc.communicate()
if args.flycheck:
if len(args.targets) == 1 and args.targets[0].endswith(".lean"): if len(args.targets) == 1 and args.targets[0].endswith(".lean"):
process_lean_output(targets[0], out, args) process_lean_output(targets[0], out, args)
handle_flycheck_failure(out, err, args) handle_flycheck_failure(out, err, args)