Compare commits
2 Commits
e06bcb895a
...
cc5f4f77da
Author | SHA1 | Date | |
---|---|---|---|
cc5f4f77da | |||
93ce2b1725 |
|
@ -1,2 +1,2 @@
|
||||||
from .track import Track
|
from .file import File
|
||||||
from .transcoder import Transcoder
|
from .transcoder import Transcoder
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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]
|
|
||||||
if album_out.exists():
|
|
||||||
print(f"Skipping '{artist.parts[-1]} / {album.parts[-1]}'")
|
|
||||||
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():
|
for file in album.iterdir():
|
||||||
if file.is_file() and file.suffix.lower() == '.flac':
|
if file.is_file():
|
||||||
transcode_list.append(Track(file))
|
transcode_list.append(File(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}")
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user