1
0
Fork 0
mirror of https://github.com/ldericher/fftcgtool synced 2025-01-15 15:02:59 +00:00
fftcgtool/main.py

91 lines
2.3 KiB
Python
Raw Normal View History

2021-08-03 00:22:00 +00:00
#!/usr/bin/env python3
2021-08-04 16:36:23 +00:00
import argparse
import logging
import os
2021-08-03 00:22:00 +00:00
2021-08-09 05:01:25 +00:00
import fftcg
# constants
2021-08-09 12:03:45 +00:00
GRID = 10, 7 # default in TTsim: 10 columns, 7 rows
RESOLUTION = 429, 600 # default in TTsim: 480x670 pixels per card
2021-08-16 12:45:15 +00:00
BOOK_YML_NAME = "book.yml"
2021-08-09 02:03:24 +00:00
def main() -> None:
# set up CLI
2021-08-04 16:36:23 +00:00
parser = argparse.ArgumentParser(
2021-08-09 04:18:56 +00:00
description="Imports FFTCG cards for TT-Sim.",
)
2021-08-04 16:36:23 +00:00
parser.add_argument(
2021-08-09 04:18:56 +00:00
"opus_id",
default="promo",
2021-08-04 22:54:15 +00:00
metavar="Opus_ID",
2021-08-04 16:36:23 +00:00
nargs="?",
2021-08-09 04:18:56 +00:00
help="the Opus to import",
)
2021-08-04 16:36:23 +00:00
parser.add_argument(
2021-08-09 04:18:56 +00:00
"-n", "--num_threads",
2021-08-04 16:36:23 +00:00
type=int,
default=20,
metavar="COUNT",
2021-08-09 04:18:56 +00:00
help="maximum number of concurrent requests",
)
2021-08-04 16:36:23 +00:00
args = parser.parse_args()
# set up logging
2021-08-09 04:18:56 +00:00
logging.basicConfig(level=logging.INFO, format="%(levelname)s: %(threadName)s %(message)s")
2021-08-04 16:36:23 +00:00
# output directory
if not os.path.exists("out"):
os.mkdir("out")
os.chdir("out")
# main program
2021-08-09 05:01:25 +00:00
opus = fftcg.Opus(args.opus_id)
book = fftcg.Book(opus, GRID, RESOLUTION, "eg", args.num_threads)
2021-08-16 12:45:15 +00:00
book.save(opus.filename, BOOK_YML_NAME)
# create elemental decks for opus
carddb = fftcg.CardDB(BOOK_YML_NAME)
def opus_filter(card: fftcg.Card):
return card.code.opus == opus.number
2021-08-16 23:35:57 +00:00
filters: list
if opus.number == "PR":
filters = [[opus_filter]]
else:
def element_filter(element: str):
return lambda card: card.elements == [element]
# simple cases: create lambdas for base elemental decks
base_elements = ["Fire", "Ice", "Wind", "Earth", "Lightning", "Water"]
element_filters = [element_filter(elem) for elem in base_elements]
element_filters += [
# light/darkness elemental deck
lambda card: card.elements == ["Light"] or card.elements == ["Darkness"],
# multi element deck
lambda card: len(card.elements) > 1,
]
# add in the opus_filter for all elemental decks
2021-08-16 23:36:37 +00:00
filters = list(zip([opus_filter] * len(element_filters), element_filters))
2021-08-16 12:45:15 +00:00
# make the decks
for f in filters:
print(carddb.make_deck(f))
# bye
logging.info("Done. Put the generated JSON files in your 'Saved Objects' Folder.")
logging.info("Thanks for using fftcgtool!")
2021-08-04 01:39:19 +00:00
2021-08-09 04:18:56 +00:00
if __name__ == "__main__":
2021-08-03 21:41:25 +00:00
main()