| #!/usr/bin/python2 | 
 | # | 
 | # Copyright (c) 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. | 
 |  | 
 | """Generate or update an existing config (.options file) for libfuzzer test. | 
 |  | 
 | Invoked by GN from fuzzer_test.gni. | 
 | """ | 
 |  | 
 | import argparse | 
 | import os | 
 | import sys | 
 |  | 
 |  | 
 | CONFIG_HEADER = '''# This is an automatically generated config for libFuzzer. | 
 | [libfuzzer] | 
 | ''' | 
 |  | 
 | def main(): | 
 |   parser = argparse.ArgumentParser(description="Generate fuzzer config.") | 
 |   parser.add_argument('--config', required=True) | 
 |   parser.add_argument('--dict') | 
 |   parser.add_argument('--libfuzzer_options', nargs='+', default=[]) | 
 |   args = parser.parse_args() | 
 |  | 
 |   # Script shouldn't be invoked without both arguments, but just in case. | 
 |   if not args.dict and not args.libfuzzer_options: | 
 |     return | 
 |  | 
 |   config_path = args.config | 
 |   # Generate .options file. | 
 |   with open(config_path, 'w') as options_file: | 
 |     options_file.write(CONFIG_HEADER) | 
 |  | 
 |     # Dict will be copied into build directory, need only basename for config. | 
 |     if args.dict: | 
 |       options_file.write('dict = %s\n' % os.path.basename(args.dict)) | 
 |  | 
 |     for option in args.libfuzzer_options: | 
 |       options_file.write(option) | 
 |       options_file.write('\n') | 
 |  | 
 | if __name__ == '__main__': | 
 |   main() |