Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(95)

Unified Diff: third_party/closure_compiler/build/inputs.py

Issue 2895773002: (fix landed)Revert of Closure: remove older, original GYP compilation system (Closed)
Patch Set: Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: third_party/closure_compiler/build/inputs.py
diff --git a/third_party/closure_compiler/build/inputs.py b/third_party/closure_compiler/build/inputs.py
new file mode 100755
index 0000000000000000000000000000000000000000..a403c25bbb425c36e2be3c2859aaefadb33812e1
--- /dev/null
+++ b/third_party/closure_compiler/build/inputs.py
@@ -0,0 +1,101 @@
+#!/usr/bin/python
+# Copyright 2014 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.
+
+import argparse
+import ast
+import collections
+import os
+import sys
+
+
+sys.path.insert(0, os.path.join(os.path.dirname(__file__), ".."))
+import processor
+
+
+def remove_duplicates_with_order(has_duplicates):
+ return list(collections.OrderedDict.fromkeys(has_duplicates))
+
+
+def expand_depends(source, dep):
+ if ":" not in dep:
+ return [dep], {}
+
+ gyp_relative_path, target = dep.split(":")
+ gyp_path = os.path.join(os.path.dirname(source), gyp_relative_path)
+ gyp_content = ast.literal_eval(open(gyp_path).read())
+
+ for target_description in gyp_content["targets"]:
+ if target_description["target_name"] == target:
+ break
+ else:
+ raise ValueError("Target '%s' not found in file '%s'" %
+ (target, gyp_path))
+
+ depends = []
+ externs = []
+ if "variables" in target_description:
+ depends = target_description["variables"].get("depends", [])
+ externs = target_description["variables"].get("externs", [])
+
+ def attach_gyp_dir(relative_path):
+ return os.path.join(os.path.dirname(gyp_path), relative_path)
+
+ target_source = attach_gyp_dir(target + ".js")
+ expanded_depends, expanded_externs = resolve_recursive_dependencies(
+ target_source,
+ depends,
+ externs)
+
+ expanded_depends = map(attach_gyp_dir, expanded_depends)
+ expanded_externs = set(map(attach_gyp_dir, expanded_externs))
+
+ expanded_depends.append(target_source)
+
+ return expanded_depends, expanded_externs
+
+
+def resolve_recursive_dependencies(source, input_depends, depends_externs):
+ output_depends = []
+ output_externs = set(depends_externs)
+
+ for depends in input_depends:
+ expanded_depends, expanded_externs = expand_depends(source, depends)
+ output_depends.extend(expanded_depends)
+ output_externs.update(expanded_externs)
+
+ output_depends = remove_duplicates_with_order(output_depends)
+
+ return output_depends, output_externs
+
+
+def GetInputs(args):
+ parser = argparse.ArgumentParser()
+ parser.add_argument("sources", nargs=argparse.ONE_OR_MORE)
+ parser.add_argument("-d", "--depends", nargs=argparse.ZERO_OR_MORE,
+ default=[])
+ parser.add_argument("-e", "--externs", nargs=argparse.ZERO_OR_MORE,
+ default=[])
+ opts = parser.parse_args(args)
+
+ # TODO(twellington): resolve dependencies for multiple sources.
+ if len(opts.sources) == 1:
+ depends, externs = resolve_recursive_dependencies(
+ os.path.normpath(os.path.join(os.getcwd(), opts.sources[0])),
+ opts.depends,
+ opts.externs)
+ else:
+ depends = opts.depends
+ externs = set(opts.externs)
+
+ files = set()
+ for file in set(opts.sources) | set(depends) | externs:
+ files.add(file)
+ files.update(processor.Processor(file).included_files)
+
+ return files
+
+
+if __name__ == "__main__":
+ print "\n".join(GetInputs(sys.argv[1:]))
« no previous file with comments | « components/chrome_apps/webstore_widget/cws_widget/compiled_resources.gypi ('k') | third_party/closure_compiler/compile.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698