From f6d0b631664f01d6e0da380bb61920195e9c76ae Mon Sep 17 00:00:00 2001 From: Alexandre Aubin Date: Wed, 28 Apr 2021 20:14:48 +0200 Subject: [PATCH] Factorize README generation into a function --- READMEs/make_readme.py | 61 +++++++++++++++++++++++------------------- 1 file changed, 33 insertions(+), 28 deletions(-) diff --git a/READMEs/make_readme.py b/READMEs/make_readme.py index 23bae03..63dc8cb 100644 --- a/READMEs/make_readme.py +++ b/READMEs/make_readme.py @@ -4,40 +4,45 @@ import os from jinja2 import Environment, FileSystemLoader -parser = argparse.ArgumentParser(description='Automatically (re)generate README for apps') -parser.add_argument('app_path', - help='Path to the app to generate/update READMEs for') -args = parser.parse_args() -app_path = args.app_path +def generate_READMEs(app_path): -if not os.path.exists(app_path): - raise Exception("App path provided doesn't exists ?!") + if not os.path.exists(app_path): + raise Exception("App path provided doesn't exists ?!") -env = Environment(loader=FileSystemLoader('./templates')) + env = Environment(loader=FileSystemLoader('./templates')) -for lang, lang_suffix in [("en", ""), ("fr", "_fr")]: + for lang, lang_suffix in [("en", ""), ("fr", "_fr")]: - template = env.get_template(f'README{lang_suffix}.md.j2') + template = env.get_template(f'README{lang_suffix}.md.j2') - manifest = json.load(open(os.path.join(app_path, "manifest.json"))) - upstream = manifest.get("upstream", {}) + manifest = json.load(open(os.path.join(app_path, "manifest.json"))) + upstream = manifest.get("upstream", {}) - if os.path.exists(os.path.join(app_path, "doc", "screenshots")): - screenshots = os.listdir(os.path.join(app_path, "doc", "screenshots")) - if ".gitkeep" in screenshots: - screenshots.remove(".gitkeep") - else: - screenshots = [] + if os.path.exists(os.path.join(app_path, "doc", "screenshots")): + screenshots = os.listdir(os.path.join(app_path, "doc", "screenshots")) + if ".gitkeep" in screenshots: + screenshots.remove(".gitkeep") + else: + screenshots = [] - if os.path.exists(os.path.join(app_path, "doc", f"DISCLAIMER{lang_suffix}.md")): - disclaimer = open(os.path.join(app_path, "doc", f"DISCLAIMER{lang_suffix}.md")).read() - # Fallback to english if maintainer too lazy to translate the disclaimer idk - elif os.path.exists(os.path.join(app_path, "doc", "DISCLAIMER.md")): - disclaimer = open(os.path.join(app_path, "doc", "DISCLAIMER.md")).read() - else: - disclaimer = None + if os.path.exists(os.path.join(app_path, "doc", f"DISCLAIMER{lang_suffix}.md")): + disclaimer = open(os.path.join(app_path, "doc", f"DISCLAIMER{lang_suffix}.md")).read() + # Fallback to english if maintainer too lazy to translate the disclaimer idk + elif os.path.exists(os.path.join(app_path, "doc", "DISCLAIMER.md")): + disclaimer = open(os.path.join(app_path, "doc", "DISCLAIMER.md")).read() + else: + disclaimer = None - out = template.render(lang=lang, upstream=upstream, screenshots=screenshots, disclaimer=disclaimer, manifest=manifest) - with open(os.path.join(app_path, f"README{lang_suffix}.md"), "w") as f: - f.write(out) + out = template.render(lang=lang, upstream=upstream, screenshots=screenshots, disclaimer=disclaimer, manifest=manifest) + with open(os.path.join(app_path, f"README{lang_suffix}.md"), "w") as f: + f.write(out) + + +if __name__ == "__main__": + parser = argparse.ArgumentParser(description='Automatically (re)generate README for apps') + parser.add_argument('app_path', + help='Path to the app to generate/update READMEs for') + + args = parser.parse_args() + generate_READMEs(args.app_path)