From 0fa329ca75c8148fa7ea10c2ed29528f371a14f7 Mon Sep 17 00:00:00 2001 From: Timmy Welch Date: Thu, 5 Dec 2024 18:43:35 -0800 Subject: [PATCH] Add language to Credit in ComicAPI --- comicapi/genericmetadata.py | 34 ++++++++++++++++++---------------- comicapi/merge.py | 6 +++++- comicapi/tags/tag.py | 1 + 3 files changed, 24 insertions(+), 17 deletions(-) diff --git a/comicapi/genericmetadata.py b/comicapi/genericmetadata.py index c6a4e1e..6713e8e 100644 --- a/comicapi/genericmetadata.py +++ b/comicapi/genericmetadata.py @@ -43,6 +43,9 @@ logger = logging.getLogger(__name__) REMOVE = object() +Credit = merge.Credit + + class PageType(merge.StrEnum): """ These page info classes are exactly the same as the CIX scheme, since @@ -108,9 +111,6 @@ class PageMetadata: ) -Credit = merge.Credit - - @dataclasses.dataclass class ComicSeries: id: str @@ -192,7 +192,7 @@ class GenericMetadata: characters: set[str] = dataclasses.field(default_factory=set) teams: set[str] = dataclasses.field(default_factory=set) locations: set[str] = dataclasses.field(default_factory=set) - credits: list[merge.Credit] = dataclasses.field(default_factory=list) + credits: list[Credit] = dataclasses.field(default_factory=list) # Some CoMet-only items price: float | None = None @@ -391,19 +391,21 @@ class GenericMetadata: return coverlist @overload - def add_credit(self, person: merge.Credit) -> None: ... + def add_credit(self, person: Credit) -> None: ... @overload - def add_credit(self, person: str, role: str, primary: bool = False) -> None: ... + def add_credit(self, person: str, role: str, primary: bool = False, language: str = "") -> None: ... - def add_credit(self, person: str | merge.Credit, role: str | None = None, primary: bool = False) -> None: + def add_credit( + self, person: str | Credit, role: str | None = None, primary: bool = False, language: str = "" + ) -> None: - credit: merge.Credit - if isinstance(person, merge.Credit): + credit: Credit + if isinstance(person, Credit): credit = person else: assert role is not None - credit = merge.Credit(person=person, role=role, primary=primary) + credit = Credit(person=person, role=role, primary=primary, language=language) if credit.role is None: raise TypeError("GenericMetadata.add_credit takes either a Credit object or a person name and role") @@ -574,12 +576,12 @@ md_test: GenericMetadata = GenericMetadata( teams={"Fahrenheit"}, locations=set(utils.split("lonely cottage ", ",")), credits=[ - merge.Credit(primary=False, person="Dara Naraghi", role="Writer"), - merge.Credit(primary=False, person="Esteve Polls", role="Penciller"), - merge.Credit(primary=False, person="Esteve Polls", role="Inker"), - merge.Credit(primary=False, person="Neil Uyetake", role="Letterer"), - merge.Credit(primary=False, person="Sam Kieth", role="Cover"), - merge.Credit(primary=False, person="Ted Adams", role="Editor"), + Credit(primary=False, person="Dara Naraghi", role="Writer"), + Credit(primary=False, person="Esteve Polls", role="Penciller"), + Credit(primary=False, person="Esteve Polls", role="Inker"), + Credit(primary=False, person="Neil Uyetake", role="Letterer"), + Credit(primary=False, person="Sam Kieth", role="Cover"), + Credit(primary=False, person="Ted Adams", role="Editor"), ], tags=set(), pages=[ diff --git a/comicapi/merge.py b/comicapi/merge.py index 8e3a724..7ca46fe 100644 --- a/comicapi/merge.py +++ b/comicapi/merge.py @@ -14,9 +14,13 @@ class Credit: person: str = "" role: str = "" primary: bool = False + language: str = "" # Should be ISO 639 language code def __str__(self) -> str: - return f"{self.role}: {self.person}" + lang = "" + if self.language: + lang = f" [{self.language}]" + return f"{self.role}: {self.person}{lang}" class Mode(StrEnum): diff --git a/comicapi/tags/tag.py b/comicapi/tags/tag.py index ef2ac8b..b303d68 100644 --- a/comicapi/tags/tag.py +++ b/comicapi/tags/tag.py @@ -61,6 +61,7 @@ class Tag: "credits.person", "credits.role", "credits.primary", + "credits.language", "price", "is_version_of", "rights",