blob: da83684dd21336043ff903d517e75c47beaee90f [file] [log] [blame]
#!/usr/bin/env python
# Copyright 2016 The Chromium Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
"""Prints all non-system dependencies for the given module.
The primary use-case for this script is to genererate the list of python modules
required for .isolate files.
import argparse
import imp
import os
import pipes
import sys
# Don't use any helper modules, or else they will end up in the results.
_SRC_ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), os.pardir))
def ComputePythonDependencies(root):
"""Gets the paths of imported non-system python modules.
A path is assumed to be a "system" import if it is outside of chromium's
src/. The paths will be relative to the current directory.
module_paths = (m.__file__ for m in sys.modules.values()
if m and hasattr(m, '__file__'))
src_paths = set()
for path in module_paths:
if path == __file__:
path = os.path.abspath(path)
if not path.startswith(_SRC_ROOT):
if path.endswith('.pyc'):
path = path[:-1]
src_paths.add(os.path.relpath(path, root))
return sorted(src_paths)
def main():
parser = argparse.ArgumentParser(
description='Prints all non-system dependencies for the given module.')
help='The python module to analyze.')
parser.add_argument('--root', default='.',
help='Directory to make paths relative to.')
help='Write output to a file rather than stdout.')
options = parser.parse_args()
imp.load_source('NAME', options.module)
out = open(options.output, 'w') if options.output else sys.stdout
with out:
out.write('# Generated by //build/\n')
out.write('# root: //%s\n' % os.path.relpath(options.root, _SRC_ROOT))
out.write('# target: //%s\n' % os.path.relpath(options.module, _SRC_ROOT))
for path in ComputePythonDependencies(options.root):
out.write(path + '\n')
if __name__ == '__main__':