From 2187ddece8df70022770b72582745a17443f10f3 Mon Sep 17 00:00:00 2001 From: Mizaki Date: Fri, 23 Jun 2023 22:38:15 +0100 Subject: [PATCH] Move volume from ComicSeries to ComicIssue --- comictalker/comiccacher.py | 39 +++++++++++++++----------------- comictalker/resulttypes.py | 2 +- comictalker/talker_utils.py | 2 +- comictalker/talkers/comicvine.py | 4 ++-- testing/comicdata.py | 2 -- testing/comicvine.py | 2 +- 6 files changed, 23 insertions(+), 28 deletions(-) diff --git a/comictalker/comiccacher.py b/comictalker/comiccacher.py index 3ab758d..51dc311 100644 --- a/comictalker/comiccacher.py +++ b/comictalker/comiccacher.py @@ -89,7 +89,6 @@ class ComicCacher: + "publisher TEXT," + "count_of_issues INT," + "count_of_volumes INT," - + "volume TEXT," + "start_year INT," + "image_url TEXT," + "aliases TEXT," # Newline separated @@ -128,6 +127,7 @@ class ComicCacher: + "maturity_rating TEXT," + "language TEXT," + "country TEXT," + + "volume TEXT," + "complete BOOL," # Is the data complete? Includes characters, locations, credits. + "PRIMARY KEY (id, source_name))" ) @@ -159,7 +159,6 @@ class ComicCacher: "publisher": record.publisher, "count_of_issues": record.count_of_issues, "count_of_volumes": record.count_of_volumes, - "volume": record.volume, "start_year": record.start_year, "image_url": record.image_url, "description": record.description, @@ -193,13 +192,12 @@ class ComicCacher: publisher=record[6], count_of_issues=record[7], count_of_volumes=record[8], - volume=record[9], - start_year=record[10], - image_url=record[11], - aliases=record[12].strip().splitlines(), - description=record[13], - genres=record[14].strip().splitlines(), - format=record[15], + start_year=record[9], + image_url=record[10], + aliases=record[11].strip().splitlines(), + description=record[12], + genres=record[13].strip().splitlines(), + format=record[14], ) results.append(result) @@ -221,7 +219,6 @@ class ComicCacher: "publisher": series_record.publisher, "count_of_issues": series_record.count_of_issues, "count_of_volumes": series_record.count_of_volumes, - "volume": series_record.volume, "start_year": series_record.start_year, "image_url": series_record.image_url, "description": series_record.description, @@ -249,6 +246,7 @@ class ComicCacher: "source_name": source_name, "name": issue.name, "issue_number": issue.issue_number, + "volume": issue.volume, "site_detail_url": issue.site_detail_url, "cover_date": issue.cover_date, "image_url": issue.image_url, @@ -300,13 +298,12 @@ class ComicCacher: publisher=row[2], count_of_issues=row[3], count_of_volumes=row[4], - volume=row[5], - start_year=row[6], - image_url=row[7], - aliases=row[8].strip().splitlines(), - description=row[9], - genres=row[10].strip().splitlines(), - format=row[11], + start_year=row[5], + image_url=row[6], + aliases=row[7].strip().splitlines(), + description=row[8], + genres=row[9].strip().splitlines(), + format=row[10], ) return result @@ -324,7 +321,6 @@ class ComicCacher: aliases=[], count_of_issues=None, count_of_volumes=None, - volume=None, format=None, ) con = lite.connect(self.db_file) @@ -355,6 +351,7 @@ class ComicCacher: id=row[0], name=row[2], issue_number=row[3], + volume=row[25], site_detail_url=row[7], cover_date=row[6], image_url=row[4], @@ -374,7 +371,7 @@ class ComicCacher: maturity_rating=row[22], language=row[23], country=row[24], - complete=bool(row[25]), + complete=bool(row[26]), ) results.append(record) @@ -410,7 +407,6 @@ class ComicCacher: aliases=[], count_of_issues=None, count_of_volumes=None, - volume=None, format=None, ) @@ -425,6 +421,7 @@ class ComicCacher: id=row[0], name=row[2], issue_number=row[3], + volume=row[25], site_detail_url=row[7], cover_date=row[6], image_url=row[4], @@ -444,7 +441,7 @@ class ComicCacher: maturity_rating=row[22], language=row[23], country=row[24], - complete=bool(row[25]), + complete=bool(row[26]), ) return record diff --git a/comictalker/resulttypes.py b/comictalker/resulttypes.py index d7a1076..7a9ef57 100644 --- a/comictalker/resulttypes.py +++ b/comictalker/resulttypes.py @@ -15,7 +15,6 @@ class ComicSeries: aliases: list[str] count_of_issues: int | None count_of_volumes: int | None - volume: str | None description: str id: str image_url: str @@ -37,6 +36,7 @@ class ComicIssue: id: str image_url: str issue_number: str + volume: str | None critical_rating: float maturity_rating: str manga: str diff --git a/comictalker/talker_utils.py b/comictalker/talker_utils.py index eba47e1..03d4d4c 100644 --- a/comictalker/talker_utils.py +++ b/comictalker/talker_utils.py @@ -51,7 +51,7 @@ def map_comic_issue_to_metadata( if issue_results.series.format: metadata.format = issue_results.series.format - metadata.volume = utils.xlate_int(issue_results.series.volume) + metadata.volume = utils.xlate_int(issue_results.volume) metadata.volume_count = utils.xlate_int(issue_results.series.count_of_volumes) if issue_results.name: diff --git a/comictalker/talkers/comicvine.py b/comictalker/talkers/comicvine.py index 337828c..8aac930 100644 --- a/comictalker/talkers/comicvine.py +++ b/comictalker/talkers/comicvine.py @@ -510,7 +510,6 @@ class ComicVineTalker(ComicTalker): aliases=aliases.splitlines(), count_of_issues=record.get("count_of_issues", 0), count_of_volumes=None, - volume=None, description=record.get("description", ""), id=str(record["id"]), image_url=image_url, @@ -527,7 +526,7 @@ class ComicVineTalker(ComicTalker): def _format_issue_results(self, issue_results: list[CVIssue], complete: bool = False) -> list[ComicIssue]: formatted_results = [] for record in issue_results: - # Extract image super and thumb to name only + # Extract image super if record.get("image") is None: image_url = "" else: @@ -572,6 +571,7 @@ class ComicVineTalker(ComicTalker): id=str(record["id"]), image_url=image_url, issue_number=record["issue_number"], + volume=None, name=record["name"], site_detail_url=record.get("site_detail_url", ""), series=series, # CV uses volume to mean series diff --git a/testing/comicdata.py b/testing/comicdata.py index 0de6540..a7f2d2b 100644 --- a/testing/comicdata.py +++ b/testing/comicdata.py @@ -8,7 +8,6 @@ search_results = [ comictalker.resulttypes.ComicSeries( count_of_issues=1, count_of_volumes=1, - volume="1", description="this is a description", id="1", image_url="https://test.org/image/1", @@ -22,7 +21,6 @@ search_results = [ comictalker.resulttypes.ComicSeries( count_of_issues=1, count_of_volumes=1, - volume="1", description="this is a description", id="2", image_url="https://test.org/image/2", diff --git a/testing/comicvine.py b/testing/comicvine.py index 562c49d..59324b4 100644 --- a/testing/comicvine.py +++ b/testing/comicvine.py @@ -165,6 +165,7 @@ comic_issue_result = ComicIssue( id=str(cv_issue_result["results"]["id"]), image_url=cv_issue_result["results"]["image"]["super_url"], issue_number=cv_issue_result["results"]["issue_number"], + volume=None, name=cv_issue_result["results"]["name"], site_detail_url=cv_issue_result["results"]["site_detail_url"], series=ComicSeries( @@ -173,7 +174,6 @@ comic_issue_result = ComicIssue( aliases=[], count_of_issues=cv_volume_result["results"]["count_of_issues"], count_of_volumes=None, - volume=None, description=cv_volume_result["results"]["description"], image_url=cv_volume_result["results"]["image"]["super_url"], publisher=cv_volume_result["results"]["publisher"]["name"],