Sha256: d01a7312a0f07f866983b39d8ce94b573596fd7646332d075919e16eae35e9b5

Contents?: true

Size: 1.37 KB

Versions: 10

Compression:

Stored size: 1.37 KB

Contents

#!/usr/bin/env python
# Copyright 2015 the V8 project authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.

"""
This script calls the first argument for each of the following arguments in
parallel. E.g.
parallel.py "clang --opt" file1 file2
calls
clang --opt file1
clang --opt file2

The output (stdout and stderr) is concatenated sequentially in the form:
______________ file1
<output of clang --opt file1>
______________ finish <exit code of clang --opt file1> ______________
______________ file2
<output of clang --opt file2>
______________ finish <exit code of clang --opt file2> ______________
"""

import itertools
import multiprocessing
import subprocess
import sys

def invoke(cmdline):
  try:
    return (subprocess.check_output(
        cmdline, shell=True, stderr=subprocess.STDOUT), 0)
  except subprocess.CalledProcessError as e:
    return (e.output, e.returncode)

if __name__ == '__main__':
  assert len(sys.argv) > 2
  processes = multiprocessing.cpu_count()
  pool = multiprocessing.Pool(processes=processes)
  cmdlines = ["%s %s" % (sys.argv[1], filename) for filename in sys.argv[2:]]
  for filename, result in itertools.izip(
      sys.argv[2:], pool.imap(invoke, cmdlines)):
    print "______________ %s" % filename
    print result[0]
    print "______________ finish %d ______________" % result[1]

Version data entries

10 entries across 9 versions & 2 rubygems

Version Path
libv8-6.0.286.54.1 vendor/v8/tools/gcmole/parallel.py
libv8-6.0.286.54.0 vendor/v8/tools/gcmole/parallel.py
libv8-6.0.286.54.0beta2 vendor/v8/tools/gcmole/parallel.py
libv8-6.0.286.54.0beta1 vendor/v8/tools/gcmole/parallel.py
libv8-6.0.286.44.0beta1 vendor/v8/tools/gcmole/parallel.py
node-compiler-0.9.1 vendor/node/deps/v8/tools/gcmole/parallel.py
node-compiler-0.9.0 vendor/node-v7.2.1/deps/v8/tools/gcmole/parallel.py
node-compiler-0.8.0 vendor/node-v7.2.0/deps/v8/tools/gcmole/parallel.py
node-compiler-0.7.0 vendor/node-v7.1.0/deps/v8/tools/gcmole/parallel.py
node-compiler-0.7.0 vendor/node-v6.9.1/deps/v8/tools/gcmole/parallel.py