| #!/usr/bin/env python3 | 
 | # | 
 | # Copyright 2018 Google Inc. All rights reserved. | 
 | # | 
 | # Licensed under the Apache License, Version 2.0 (the "License"); | 
 | # you may not use this file except in compliance with the License. | 
 | # You may obtain a copy of the License at | 
 | # | 
 | #     http://www.apache.org/licenses/LICENSE-2.0 | 
 | # | 
 | # Unless required by applicable law or agreed to in writing, software | 
 | # distributed under the License is distributed on an "AS IS" BASIS, | 
 | # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
 | # See the License for the specific language governing permissions and | 
 | # limitations under the License. | 
 |  | 
 | # Generates kotlinc module xml file to drive kotlinc | 
 |  | 
 | import argparse | 
 | import os | 
 |  | 
 | from ninja_rsp import NinjaRspFileReader | 
 |  | 
 | def parse_args(): | 
 |   """Parse commandline arguments.""" | 
 |  | 
 |   def convert_arg_line_to_args(arg_line): | 
 |     for arg in arg_line.split(): | 
 |       if arg.startswith('#'): | 
 |         return | 
 |       if not arg.strip(): | 
 |         continue | 
 |       yield arg | 
 |  | 
 |   parser = argparse.ArgumentParser(fromfile_prefix_chars='@') | 
 |   parser.convert_arg_line_to_args = convert_arg_line_to_args | 
 |   parser.add_argument('--out', dest='out', | 
 |                       help='file to which the module.xml contents will be written.') | 
 |   parser.add_argument('--classpath', dest='classpath', action='append', default=[], | 
 |                       help='file containing classpath to pass to kotlinc.') | 
 |   parser.add_argument('--name', dest='name', | 
 |                       help='name of the module.') | 
 |   parser.add_argument('--out_dir', dest='out_dir', | 
 |                       help='directory to which kotlinc will write output files.') | 
 |   parser.add_argument('--srcs', dest='srcs', action='append', default=[], | 
 |                       help='file containing whitespace separated list of source files.') | 
 |   parser.add_argument('--common_srcs', dest='common_srcs', action='append', default=[], | 
 |                       help='file containing whitespace separated list of common multiplatform source files.') | 
 |  | 
 |   return parser.parse_args() | 
 |  | 
 | def main(): | 
 |   """Program entry point.""" | 
 |   args = parse_args() | 
 |  | 
 |   if not args.out: | 
 |     raise RuntimeError('--out argument is required') | 
 |  | 
 |   if not args.name: | 
 |     raise RuntimeError('--name argument is required') | 
 |  | 
 |   with open(args.out, 'w') as f: | 
 |     # Print preamble | 
 |     f.write('<modules>\n') | 
 |     f.write('  <module name="%s" type="java-production" outputDir="%s">\n' % (args.name, args.out_dir or '')) | 
 |  | 
 |     # Print classpath entries | 
 |     for classpath_rsp_file in args.classpath: | 
 |       for entry in NinjaRspFileReader(classpath_rsp_file): | 
 |         path = os.path.abspath(entry) | 
 |         f.write('    <classpath path="%s"/>\n' % path) | 
 |  | 
 |     # For each rsp file, print source entries | 
 |     for rsp_file in args.srcs: | 
 |       for src in NinjaRspFileReader(rsp_file): | 
 |         path = os.path.abspath(src) | 
 |         if src.endswith('.java'): | 
 |           f.write('    <javaSourceRoots path="%s"/>\n' % path) | 
 |         elif src.endswith('.kt'): | 
 |           f.write('    <sources path="%s"/>\n' % path) | 
 |         else: | 
 |           raise RuntimeError(f'unknown source file type {src} from rspfile {rsp_file}') | 
 |  | 
 |     for rsp_file in args.common_srcs: | 
 |       for src in NinjaRspFileReader(rsp_file): | 
 |         path = os.path.abspath(src) | 
 |         f.write('    <sources path="%s"/>\n' % path) | 
 |         f.write('    <commonSources path="%s"/>\n' % path) | 
 |  | 
 |     f.write('  </module>\n') | 
 |     f.write('</modules>\n') | 
 |  | 
 | if __name__ == '__main__': | 
 |   main() |