Index: build/write_buildflag_header.py |
diff --git a/build/write_buildflag_header.py b/build/write_buildflag_header.py |
new file mode 100755 |
index 0000000000000000000000000000000000000000..d46cfc89a9dcdbddf0d32ce6f45a60c30b3132a8 |
--- /dev/null |
+++ b/build/write_buildflag_header.py |
@@ -0,0 +1,95 @@ |
+#!/usr/bin/env python |
+# Copyright 2015 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. |
+ |
+# This writes headers for build flags. See buildflag_header.gni for usage of |
+# this system as a whole. |
+# |
+# The parameters are passed in a response file so we don't have to worry |
+# about command line lengths. The name of the response file is passed on the |
+# command line. |
+# |
+# The format of the response file is: |
+# [--flags <list of one or more flag values>] |
+ |
+import optparse |
+import os |
+import shlex |
+import sys |
+ |
+ |
+class Options: |
+ def __init__(self, output, rulename, header_guard, flags): |
+ self.output = output |
+ self.rulename = rulename |
+ self.header_guard = header_guard |
+ self.flags = flags |
+ |
+ |
+def GetOptions(): |
+ parser = optparse.OptionParser() |
+ parser.add_option('--output', help="Output header name inside --gen-dir.") |
+ parser.add_option('--rulename', |
+ help="Helpful name of build rule for including in the " + |
+ "comment at the top of the file.") |
+ parser.add_option('--gen-dir', |
+ help="Path to root of generated file directory tree.") |
+ parser.add_option('--definitions', |
+ help="Name of the response file containing the flags.") |
+ cmdline_options, cmdline_flags = parser.parse_args() |
+ |
+ # Compute header guard by replacing some chars with _ and upper-casing. |
+ header_guard = cmdline_options.output.upper() |
+ header_guard = \ |
+ header_guard.replace('/', '_').replace('\\', '_').replace('.', '_') |
+ header_guard += '_' |
+ |
+ # The actual output file is inside the gen dir. |
+ output = os.path.join(cmdline_options.gen_dir, cmdline_options.output) |
+ |
+ # Definition file in GYP is newline separated, in GN they are shell formatted. |
+ # shlex can parse both of these. |
+ with open(cmdline_options.definitions, 'r') as def_file: |
+ defs = shlex.split(def_file.read()) |
+ flags_index = defs.index('--flags') |
+ |
+ # Everything after --flags are flags. true/false are remapped to 1/0, |
+ # everything else is passed through. |
+ flags = [] |
+ for flag in defs[flags_index + 1 :]: |
+ equals_index = flag.index('=') |
+ key = flag[:equals_index] |
+ value = flag[equals_index + 1:] |
+ |
+ # Canonicalize and validate the value. |
+ if value == 'true': |
+ value = '1' |
+ elif value == 'false': |
+ value = '0' |
+ flags.append((key, str(value))) |
+ |
+ return Options(output=output, |
+ rulename=cmdline_options.rulename, |
+ header_guard=header_guard, |
+ flags=flags) |
+ |
+ |
+def WriteHeader(options): |
+ with open(options.output, 'w') as output_file: |
+ output_file.write("// Generated by build/write_buildflag_header.py\n") |
+ if options.rulename: |
+ output_file.write('// From "' + options.rulename + '"\n') |
+ |
+ output_file.write('\n#ifndef %s\n' % options.header_guard) |
+ output_file.write('#define %s\n\n' % options.header_guard) |
+ output_file.write('#include "build/buildflag.h"\n\n') |
+ |
+ for pair in options.flags: |
+ output_file.write('#define BUILDFLAG_INTERNAL_%s() (%s)\n' % pair) |
+ |
+ output_file.write('\n#endif // %s\n' % options.header_guard) |
+ |
+ |
+options = GetOptions() |
+WriteHeader(options) |