Compare commits

..

2 Commits

Author SHA1 Message Date
cc5f4f77da Rename class Track to File 2025-01-18 14:53:31 +00:00
93ce2b1725 Copy album art using Track class 2025-01-18 14:46:59 +00:00
3 changed files with 44 additions and 36 deletions

View File

@ -1,2 +1,2 @@
from .track import Track from .file import File
from .transcoder import Transcoder from .transcoder import Transcoder

View File

@ -1,10 +1,10 @@
from pathlib import Path from pathlib import Path
audio_extensions = ['flac'] audio_extensions = ['.flac']
art_extensions = ['.jpg', '.jpeg', '.png'] art_extensions = ['.jpg', '.jpeg', '.png']
class Track: class File:
def __init__(self, location: Path): def __init__(self, location: Path):
self.path = location self.path = location

View File

@ -2,7 +2,7 @@ from pathlib import Path
import shutil import shutil
import subprocess import subprocess
from multiprocessing import Pool from multiprocessing import Pool
from . import Track from . import File
class Transcoder: class Transcoder:
@ -16,29 +16,18 @@ class Transcoder:
transcode_list = [] transcode_list = []
for artist in self.input_root.iterdir(): for artist in self.input_root.iterdir():
if artist.is_dir(): if artist.is_dir():
artist_out = Path(self.output_root) / artist.name
artist_out.mkdir()
for album in artist.iterdir(): for album in artist.iterdir():
if album.is_dir(): if album.is_dir():
album_out = artist_out / album.parts[-1] for file in album.iterdir():
if album_out.exists(): if file.is_file():
print(f"Skipping '{artist.parts[-1]} / {album.parts[-1]}'") transcode_list.append(File(file))
else:
album_out.mkdir()
done_file = album / 'DONE'
open(done_file, 'a').close()
self.copy_album_art(album, album_out)
for file in album.iterdir():
if file.is_file() and file.suffix.lower() == '.flac':
transcode_list.append(Track(file))
else: else:
print(f"Warning, skipping non-dir '{album}' found in artist '{artist.parts[-1]}'") print(f"Warning, skipping non-dir '{album}' found in artist '{artist.parts[-1]}'")
continue continue
else: else:
print(f"Warning, skipping non-dir '{artist}' found in root") print(f"Warning, skipping non-dir '{artist}' found in root")
continue continue
self._transcode_single_thread(transcode_list, self.encoder) self._transcode(transcode_list, self.encoder)
#self._transcode(transcode_list, self.encoder)
def _transcode(self, transcode_list: list, encoder: Path, workers=16): def _transcode(self, transcode_list: list, encoder: Path, workers=16):
worker_args = [(track, encoder) for track in transcode_list] worker_args = [(track, encoder) for track in transcode_list]
@ -52,13 +41,36 @@ class Transcoder:
def _transcode_single_thread(self, transcode_list: list, encoder: Path): def _transcode_single_thread(self, transcode_list: list, encoder: Path):
worker_args = [(track, encoder) for track in transcode_list] worker_args = [(track, encoder) for track in transcode_list]
for args in worker_args: for args in worker_args:
print(f"{args[0]}") print(self.transcode_worker(*args))
self.transcode_worker(*args)
def transcode_worker(self, track, encoder): def transcode_worker(self, track, encoder):
if track.is_art:
return self.copy_album_art(track)
elif track.is_audio:
return self.transcode_audio(track, encoder)
else:
return f"File {track.path} ignored"
def copy_album_art(self, file: File):
self.create_directories(file)
output_path = file.output_file(self.output_root, file.extension[1:])
if output_path.exists():
return f"Skipped {output_path}"
try:
shutil.copy(file.path, output_path)
return f"Successfully copied {output_path}"
except FileExistsError:
pass
except Exception:
return f"{file.path} failed to copy"
def transcode_audio(self, track, encoder):
enc_filename = encoder.parts[-1] enc_filename = encoder.parts[-1]
track_output = track.output_file(self.output_root, self.extension) track_output = track.output_file(self.output_root, self.extension)
if track_output.exists():
return f"Skipped {track_output}"
self.create_directories(track)
if enc_filename == "opusenc.exe": if enc_filename == "opusenc.exe":
additional_args = ('--bitrate', '128', '--music') additional_args = ('--bitrate', '128', '--music')
subprocess_args = (str(encoder),) + additional_args + (str(track.path), str(track_output)) subprocess_args = (str(encoder),) + additional_args + (str(track.path), str(track_output))
@ -71,18 +83,14 @@ class Transcoder:
except Exception: except Exception:
return f"ERROR: Transcoding of '{track}' failed." return f"ERROR: Transcoding of '{track}' failed."
@staticmethod def create_directories(self, track: File):
def copy_album_art(in_dir: Path, out_dir: Path, file_whitelist: list = None): if not track.artist_out(self.output_root).exists():
if file_whitelist is None: try:
file_whitelist = ['.jpg', '.jpeg', '.png'] track.artist_out(self.output_root).mkdir()
art_file_name = "cover.jpg" except FileExistsError:
pass
art_found = False if not track.album_out(self.output_root).exists():
for file in in_dir.iterdir(): try:
if file.is_file() and file.suffix.lower() in file_whitelist: track.album_out(self.output_root).mkdir()
if file.name == art_file_name: except FileExistsError:
art_found = True pass
shutil.copy(file, out_dir / file.name)
if not art_found:
print(f"Warning: {art_file_name} not found in {in_dir}")