Index: tools/BUILD_simulator.py |
diff --git a/tools/BUILD_simulator.py b/tools/BUILD_simulator.py |
old mode 100644 |
new mode 100755 |
index 65e6b7d11ed769ce5369baffb3dfee644a7390ba..46d3cd79e7008511d4b322b4153ef488565c5da4 |
--- a/tools/BUILD_simulator.py |
+++ b/tools/BUILD_simulator.py |
@@ -10,33 +10,34 @@ |
# We start by adding some symbols to our namespace that BUILD.public calls. |
-# We don't really care about this, so just no-op it. |
-def exports_files(files): |
+import glob |
+import pprint |
+ |
+def noop(*args, **kwargs): |
pass |
# Simulates BUILD file glob(). |
-def glob(include, exclude=()): |
- from glob import glob as python_glob |
- |
+def BUILD_glob(include, exclude=()): |
files = set() |
for pattern in include: |
- files.update(python_glob(pattern)) |
+ files.update(glob.glob(pattern)) |
for pattern in exclude: |
- files.difference_update(python_glob(pattern)) |
+ files.difference_update(glob.glob(pattern)) |
return list(sorted(files)) |
-# We've put enough into our environment now to treat BUILD.public as if it were |
-# Python code. This pulls its variable definitions (SRCS, HDRS, DEFINES, etc.) |
-# into our local namespace. |
-execfile('BUILD.public') |
+# With these namespaces, we can treat BUILD.public as if it were |
+# Python code. This pulls its variable definitions (SRCS, HDRS, |
+# DEFINES, etc.) into local_names. |
+global_names = { |
+ 'exports_files': noop, |
+ 'glob': BUILD_glob, |
+} |
+local_names = {} |
+execfile('BUILD.public', global_names, local_names) |
-# Pretty-print every variable whose name is COMPLETELY_UPPERCASE, |
-# i.e. every variable from BUILD.public. This is obviously quite heuristic. |
-from pprint import pprint |
with open('tools/BUILD.public.expected', 'w') as out: |
print >>out, "This file is auto-generated by tools/BUILD_simulator.py." |
print >>out, "It expands BUILD.public to make it easy to see changes." |
- for name, value in sorted(locals().items()): |
- if name.isupper(): |
- print >>out, name, '= ', |
- pprint(value, out) |
+ for name, value in sorted(local_names.items()): |
+ print >>out, name, '= ', |
+ pprint.pprint(value, out) |