From 0ec072c79756ccf15c306bb0b643d955af4488a8 Mon Sep 17 00:00:00 2001 From: Ethan Dalool Date: Tue, 29 Sep 2020 18:08:04 -0700 Subject: [PATCH] Add breplace. --- frontends/etiquette_cli.py | 46 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) diff --git a/frontends/etiquette_cli.py b/frontends/etiquette_cli.py index f14cefb..b6d748c 100644 --- a/frontends/etiquette_cli.py +++ b/frontends/etiquette_cli.py @@ -30,6 +30,44 @@ def find_photodb(): #################################################################################################### +def tag_breplace_argparse(args): + photodb = find_photodb() + renames = [] + tag_names = photodb.get_all_tag_names() + all_names = tag_names.union(photodb.get_all_synonyms()) + for tag_name in tag_names: + if args.regex: + new_name = re.sub(args.replace_from, args.replace_to, tag_name) + else: + new_name = tag_name.replace(args.replace_from, args.replace_to) + new_name = photodb.normalize_tagname(new_name) + if new_name == tag_name: + continue + + if new_name in all_names: + raise etiquette.exceptions.TagExists(new_name) + + if args.set_synonym: + printline = f'{tag_name} -> {new_name}+{tag_name}' + else: + printline = f'{tag_name} -> {new_name}' + + renames.append((tag_name, new_name, printline)) + + if not args.autoyes: + for (tag_name, new_name, printline) in renames: + print(printline) + if not getpermission.getpermission('Ok?', must_pick=True): + return + + for (tag_name, new_name, printline) in renames: + print(printline) + tag = photodb.get_tag(tag_name) + tag.rename(new_name) + if args.set_synonym: + tag.add_synonym(tag_name) + photodb.commit() + def digest_directory_argparse(args): directory = pathclass.Path(args.directory) photodb = find_photodb() @@ -102,6 +140,14 @@ def main(argv): continue mode.append(arg) + p_tag_breplace = subparsers.add_parser('tag_breplace') + p_tag_breplace.add_argument('replace_from') + p_tag_breplace.add_argument('replace_to') + p_tag_breplace.add_argument('--set_synonym', '--set-synonym', dest='set_synonym', action='store_true') + p_tag_breplace.add_argument('--regex', dest='regex', action='store_true') + p_tag_breplace.add_argument('--yes', dest='autoyes', action='store_true') + p_tag_breplace.set_defaults(func=tag_breplace_argparse) + p_digest = subparsers.add_parser('digest', aliases=['digest_directory', 'digest-directory']) p_digest.add_argument('directory') p_digest.add_argument('--no_albums', '--no-albums', dest='make_albums', action='store_false', default=True)