From 972e76aee3c72cef55feb0ada250af6eb69fbb56 Mon Sep 17 00:00:00 2001 From: Alexander Alemayhu Date: Thu, 17 Oct 2024 03:03:15 +0000 Subject: [PATCH] fix: long file names (#95) --- .pylintrc | 4 ++-- helpers/write_apkg.py | 33 +++++++++++++++++++++++++-------- 2 files changed, 27 insertions(+), 10 deletions(-) diff --git a/.pylintrc b/.pylintrc index 9f5b060..b9f50d0 100644 --- a/.pylintrc +++ b/.pylintrc @@ -336,7 +336,7 @@ indent-after-paren=4 indent-string=' ' # Maximum number of characters on a single line. -max-line-length=100 +max-line-length=150 # Maximum number of lines in a module. max-module-lines=1000 @@ -629,4 +629,4 @@ init-import=no # builtins. redefining-builtins-modules=six.moves,past.builtins,future.builtins,builtins,io -disable=import-error \ No newline at end of file +disable=import-error diff --git a/helpers/write_apkg.py b/helpers/write_apkg.py index 304da04..20d4b0f 100644 --- a/helpers/write_apkg.py +++ b/helpers/write_apkg.py @@ -1,11 +1,13 @@ +""" +This module provides functionality to write a new Anki package file (.apkg) using provided deck payloads and media files. +""" + import os import sys import re -from genanki import Deck, Package +import tempfile -""" -This module provides functionality to write a new Anki package file (.apkg) using provided deck payloads and media files. -""" +from genanki import Deck, Package def sanitize_filename(filename): """ @@ -44,7 +46,7 @@ def _write_new_apkg(deck_payloads, media_files): package = Package(decks) package.media_files = media_files - # Ensure deck_payload is defined before using it + # Ensure deck_payloads is defined before using it if deck_payloads: sanitized_name = sanitize_filename(deck_payloads[0]["name"]) else: @@ -53,8 +55,23 @@ def _write_new_apkg(deck_payloads, media_files): max_name_length = 255 - len(first_deck_id) - len('.apkg') - 1 truncated_name = sanitized_name[:max_name_length] - output_filename = f'{truncated_name}-{first_deck_id}.apkg' + # Use a temporary file to avoid file name too long errors + with tempfile.NamedTemporaryFile(delete=False) as tmp_file: + output_filename = f'{truncated_name}-{first_deck_id}.apkg' + tmp_file.name = output_filename + + try: + package.write_to_file(tmp_file.name) + except OSError as error: + if error.errno == 36: # File name too long + tmp_file.name = ( + f'{truncated_name[:max_name_length - 10]}-truncated-{first_deck_id}.apkg' + ) + package.write_to_file(tmp_file.name) + else: + raise error # Re-raise other exceptions - package.write_to_file(output_filename) + final_path = os.path.join(os.getcwd(), tmp_file.name) + os.rename(tmp_file.name, final_path) - sys.stdout.write(os.getcwd() + "/" + output_filename) + sys.stdout.write(final_path)