From f91216b9cf9fdd04eb7227de4b7d497472dc4ccd Mon Sep 17 00:00:00 2001 From: Martin Bernstorff Date: Sat, 18 Nov 2023 16:30:41 +0000 Subject: [PATCH] feat: move cli to separate file --- application/cli.py | 6 ++++++ application/main.py | 23 ++++++++++++++++------- 2 files changed, 22 insertions(+), 7 deletions(-) create mode 100644 application/cli.py diff --git a/application/cli.py b/application/cli.py new file mode 100644 index 0000000..fcaf30b --- /dev/null +++ b/application/cli.py @@ -0,0 +1,6 @@ +import typer + +from application.main import main + +if __name__ == "__main__": + typer.run(main) diff --git a/application/main.py b/application/main.py index 95fcd1b..86edade 100644 --- a/application/main.py +++ b/application/main.py @@ -1,11 +1,14 @@ +from collections import defaultdict from pathlib import Path from time import sleep from typing import Annotated, Any import sentry_sdk import typer -from functionalpy import Seq from personal_mnemonic_medium.card_pipeline import CardPipeline +from personal_mnemonic_medium.exporters.anki.card_types.base import ( + AnkiCard, +) from personal_mnemonic_medium.exporters.anki.package_generator import ( AnkiPackageGenerator, ) @@ -75,12 +78,13 @@ def main( card_exporter=AnkiPackageGenerator(), # Step 3, get the cards from the prompts ).run(input_path=input_dir) - grouped_cards = ( - Seq(cards).group_by(lambda card: card.deckname).to_iter() - ) + decks: dict[str, list[AnkiCard]] = defaultdict(list) - for group in grouped_cards: - cards = group.group_contents.to_list() + for card in cards: + decks[card.deckname] += [card] + + for deck in decks: + cards = decks[deck] deck_bundle = AnkiPackageGenerator().cards_to_deck_bundle( cards=cards ) @@ -107,4 +111,9 @@ def main( if __name__ == "__main__": - typer.run(main) + main( + input_dir=Path("/input"), + host_output_dir=Path("/Users/au484925/ankidecks/"), + watch=True, + use_anki_connect=True, + )