| OLD | NEW |
| (Empty) |
| 1 #!/usr/bin/env python | |
| 2 # Copyright 2015 The Chromium Authors. All rights reserved. | |
| 3 # Use of this source code is governed by a BSD-style license that can be | |
| 4 # found in the LICENSE file. | |
| 5 | |
| 6 # This writes headers for build flags. See buildflag_header.gni for usage of | |
| 7 # this system as a whole. | |
| 8 # | |
| 9 # The parameters are passed in a response file so we don't have to worry | |
| 10 # about command line lengths. The name of the response file is passed on the | |
| 11 # command line. | |
| 12 # | |
| 13 # The format of the response file is: | |
| 14 # [--flags <list of one or more flag values>] | |
| 15 | |
| 16 import optparse | |
| 17 import os | |
| 18 import shlex | |
| 19 import sys | |
| 20 | |
| 21 | |
| 22 class Options: | |
| 23 def __init__(self, output, rulename, header_guard, flags): | |
| 24 self.output = output | |
| 25 self.rulename = rulename | |
| 26 self.header_guard = header_guard | |
| 27 self.flags = flags | |
| 28 | |
| 29 | |
| 30 def GetOptions(): | |
| 31 parser = optparse.OptionParser() | |
| 32 parser.add_option('--output', help="Output header name inside --gen-dir.") | |
| 33 parser.add_option('--rulename', | |
| 34 help="Helpful name of build rule for including in the " + | |
| 35 "comment at the top of the file.") | |
| 36 parser.add_option('--gen-dir', | |
| 37 help="Path to root of generated file directory tree.") | |
| 38 parser.add_option('--definitions', | |
| 39 help="Name of the response file containing the flags.") | |
| 40 cmdline_options, cmdline_flags = parser.parse_args() | |
| 41 | |
| 42 # Compute header guard by replacing some chars with _ and upper-casing. | |
| 43 header_guard = cmdline_options.output.upper() | |
| 44 header_guard = \ | |
| 45 header_guard.replace('/', '_').replace('\\', '_').replace('.', '_') | |
| 46 header_guard += '_' | |
| 47 | |
| 48 # The actual output file is inside the gen dir. | |
| 49 output = os.path.join(cmdline_options.gen_dir, cmdline_options.output) | |
| 50 | |
| 51 # Definition file in GYP is newline separated, in GN they are shell formatted. | |
| 52 # shlex can parse both of these. | |
| 53 with open(cmdline_options.definitions, 'r') as def_file: | |
| 54 defs = shlex.split(def_file.read()) | |
| 55 flags_index = defs.index('--flags') | |
| 56 | |
| 57 # Everything after --flags are flags. true/false are remapped to 1/0, | |
| 58 # everything else is passed through. | |
| 59 flags = [] | |
| 60 for flag in defs[flags_index + 1 :]: | |
| 61 equals_index = flag.index('=') | |
| 62 key = flag[:equals_index] | |
| 63 value = flag[equals_index + 1:] | |
| 64 | |
| 65 # Canonicalize and validate the value. | |
| 66 if value == 'true': | |
| 67 value = '1' | |
| 68 elif value == 'false': | |
| 69 value = '0' | |
| 70 flags.append((key, str(value))) | |
| 71 | |
| 72 return Options(output=output, | |
| 73 rulename=cmdline_options.rulename, | |
| 74 header_guard=header_guard, | |
| 75 flags=flags) | |
| 76 | |
| 77 | |
| 78 def WriteHeader(options): | |
| 79 with open(options.output, 'w') as output_file: | |
| 80 output_file.write("// Generated by build/write_buildflag_header.py\n") | |
| 81 if options.rulename: | |
| 82 output_file.write('// From "' + options.rulename + '"\n') | |
| 83 | |
| 84 output_file.write('\n#ifndef %s\n' % options.header_guard) | |
| 85 output_file.write('#define %s\n\n' % options.header_guard) | |
| 86 output_file.write('#include "build/buildflag.h"\n\n') | |
| 87 | |
| 88 for pair in options.flags: | |
| 89 output_file.write('#define BUILDFLAG_INTERNAL_%s() (%s)\n' % pair) | |
| 90 | |
| 91 output_file.write('\n#endif // %s\n' % options.header_guard) | |
| 92 | |
| 93 | |
| 94 options = GetOptions() | |
| 95 WriteHeader(options) | |
| OLD | NEW |