diff options
-rw-r--r-- | movement/template/watch_face.py | 52 |
1 files changed, 30 insertions, 22 deletions
diff --git a/movement/template/watch_face.py b/movement/template/watch_face.py index 85a0f8b2..4833c382 100644 --- a/movement/template/watch_face.py +++ b/movement/template/watch_face.py @@ -22,6 +22,7 @@ import os import re +import sys import datetime import argparse @@ -40,7 +41,7 @@ def replace_placeholders(contents, args): return modified_contents -def write_output_file(args, file_type, output_dir): +def write_modified_template(args, file_type, output_dir): with open(f"template.{file_type}", 'r') as file_template: file_contents = file_template.read() modified_template = replace_placeholders(file_contents, args) @@ -48,47 +49,54 @@ def write_output_file(args, file_type, output_dir): if not os.path.exists(file_path): with open(file_path, 'w') as output_file: output_file.write(modified_template) + print(f"Created {file_path}.") else: print(f"Generation failed: the watch face \"{args.watch_face_name}\" already exists at {file_path}. Unable to generate new files. Exiting...") - exit(0) + sys.exit(0) -def write_include_file(file_path, file_type, indicator_line, line_to_insert): +def update_include_file(file_path, indicator_line, line_to_insert): with open(file_path, 'r+') as include_file: include_contents = include_file.readlines() - if line_to_insert in include_contents: + if line_to_insert not in include_contents: + new_face_index = include_contents.index(indicator_line) + include_contents.insert(new_face_index, line_to_insert) + include_file.seek(0) + include_file.writelines(include_contents) + print(f"Updated {file_path}.") + else: print(f"Generation failed: {file_path} already has an entry for {line_to_insert.strip()}. Unable to generate new files. Exiting...") - exit(0) - new_face_index = include_contents.index(indicator_line) - include_contents.insert(new_face_index, line_to_insert) - include_file.seek(0) - include_file.writelines(include_contents) - + sys.exit(0) + def main(): parser = argparse.ArgumentParser(description="Create a new watch face.") parser.add_argument("watch_face_type", metavar="face_type", type=str, choices=["complication", "clock"], help="The type of watch face to create, either \"complication\" or \"clock\"") parser.add_argument("watch_face_name", metavar="face_name", type=str, help="The name of the watch face") - parser.add_argument("--author_name", metavar="author_name", type=str, nargs='*', help="The name of the author") + parser.add_argument("--author-name", metavar="author_name", type=str, nargs='*', help="The name of the author") args = parser.parse_args() - + name_valid = re.fullmatch(r'[a-zA-Z_][a-zA-Z0-9_]*', args.watch_face_name) - if name_valid == None: + if name_valid is None: print(f"Generation failed: {args.watch_face_name} is not a valid C variable name. Exiting...") - exit(0) - + sys.exit(0) + + if not args.author_name: + print("Note: the \"--author-name\" argument was not supplied via command line. \"<#author_name#>\" will not be replaced in generated template.") + line_to_insert = f"#include \"{args.watch_face_name}_face.h\"\n" - write_include_file(f"..{os.sep}movement_faces.h", "h", INCLUDE_INDICATOR, line_to_insert) - + update_include_file(f"..{os.sep}movement_faces.h", INCLUDE_INDICATOR, line_to_insert) + line_to_insert = f" ..{os.sep}watch_faces{os.sep}{args.watch_face_type}{os.sep}{args.watch_face_name}_face.c \\\n" - write_include_file(f"..{os.sep}make{os.sep}Makefile", "c", MAKEFILE_INDICATOR, line_to_insert) - + update_include_file(f"..{os.sep}make{os.sep}Makefile", MAKEFILE_INDICATOR, line_to_insert) + output_dir = f"..{os.sep}watch_faces{os.sep}{args.watch_face_type}{os.sep}" - write_output_file(args, "h", output_dir) - write_output_file(args, "c", output_dir) + write_modified_template(args, "h", output_dir) + write_modified_template(args, "c", output_dir) + + print(f"Successfully generated the {args.watch_face_name} {args.watch_face_type} and updated include files.") if __name__ == "__main__": main() - |