From 3fd1c13ecbfacd0c8fc654fd641bb59df8f5de22 Mon Sep 17 00:00:00 2001 From: Timmy Welch Date: Sat, 22 Jun 2024 20:19:02 -0700 Subject: [PATCH] Fixes for metadata parsing and printing --- comicapi/genericmetadata.py | 5 ++++- comictaggerlib/ctsettings/types.py | 23 ++++++++++++----------- 2 files changed, 16 insertions(+), 12 deletions(-) diff --git a/comicapi/genericmetadata.py b/comicapi/genericmetadata.py index ac41ed0..b6842cc 100644 --- a/comicapi/genericmetadata.py +++ b/comicapi/genericmetadata.py @@ -385,16 +385,19 @@ class GenericMetadata: return "No metadata" def add_string(tag: str, val: Any) -> None: - if isinstance(val, Sequence): + if isinstance(val, (Sequence, set)): if val: vals.append((tag, val)) elif val is not None: vals.append((tag, val)) + add_string("data_origin", self.data_origin) add_string("series", self.series) + add_string("series_aliases", ",".join(self.series_aliases)) add_string("issue", self.issue) add_string("issue_count", self.issue_count) add_string("title", self.title) + add_string("title_aliases", ",".join(self.title_aliases)) add_string("publisher", self.publisher) add_string("year", self.year) add_string("month", self.month) diff --git a/comictaggerlib/ctsettings/types.py b/comictaggerlib/ctsettings/types.py index 0b4104a..97ccf14 100644 --- a/comictaggerlib/ctsettings/types.py +++ b/comictaggerlib/ctsettings/types.py @@ -180,19 +180,20 @@ def parse_metadata_from_string(mdstr: str) -> GenericMetadata: return t def convert_value(t: type, value: Any) -> Any: - if not isinstance(value, t): + if isinstance(value, t): + return value + try: if isinstance(value, (Mapping)): value = t(**value) elif not isinstance(value, str) and isinstance(value, (Collection)): value = t(*value) else: - try: - if t is utils.Url and isinstance(value, str): - value = utils.parse_url(value) - else: - value = t(value) - except (ValueError, TypeError): - raise argparse.ArgumentTypeError(f"Invalid syntax for tag '{key}'") + if t is utils.Url and isinstance(value, str): + value = utils.parse_url(value) + else: + value = t(value) + except (ValueError, TypeError): + raise argparse.ArgumentTypeError(f"Invalid syntax for tag '{key}': {value}") return value md = GenericMetadata() @@ -217,11 +218,11 @@ def parse_metadata_from_string(mdstr: str) -> GenericMetadata: if value is None: value = REMOVE elif isinstance(t, tuple): - if value == "" or value is None: + if value == "": value = t[0]() else: if isinstance(value, str): - values: list[Any] = value.split("::") + value = [value] if not isinstance(value, Collection): raise argparse.ArgumentTypeError(f"Invalid syntax for tag '{key}'") values = list(value) @@ -229,7 +230,7 @@ def parse_metadata_from_string(mdstr: str) -> GenericMetadata: if not isinstance(v, t[1]): values[idx] = convert_value(t[1], v) value = t[0](values) - elif value is not None: + else: value = convert_value(t, value) empty = False