mirror of https://github.com/devine-dl/devine.git
Add Audio Channels Selection option to dl command CLI
Sub-channel layouts like 5.1, 7.1, will match with e.g., 6.0 and 8.0 respectively. Closes #9.
This commit is contained in:
parent
f9afd87474
commit
d612599e27
|
@ -2,6 +2,7 @@ from __future__ import annotations
|
||||||
|
|
||||||
import html
|
import html
|
||||||
import logging
|
import logging
|
||||||
|
import math
|
||||||
import random
|
import random
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
|
@ -71,6 +72,9 @@ class dl:
|
||||||
@click.option("-r", "--range", "range_", type=click.Choice(Video.Range, case_sensitive=False),
|
@click.option("-r", "--range", "range_", type=click.Choice(Video.Range, case_sensitive=False),
|
||||||
default=Video.Range.SDR,
|
default=Video.Range.SDR,
|
||||||
help="Video Color Range, defaults to SDR.")
|
help="Video Color Range, defaults to SDR.")
|
||||||
|
@click.option("-c", "--channels", type=float,
|
||||||
|
default=None,
|
||||||
|
help="Audio Channel(s) to download. Matches sub-channel layouts like 5.1 with 6.0 implicitly.")
|
||||||
@click.option("-w", "--wanted", type=SEASON_RANGE, default=None,
|
@click.option("-w", "--wanted", type=SEASON_RANGE, default=None,
|
||||||
help="Wanted episodes, e.g. `S01-S05,S07`, `S01E01-S02E03`, `S02-S02E03`, e.t.c, defaults to all.")
|
help="Wanted episodes, e.g. `S01-S05,S07`, `S01E01-S02E03`, `S02-S02E03`, e.t.c, defaults to all.")
|
||||||
@click.option("-l", "--lang", type=LANGUAGE_RANGE, default="en",
|
@click.option("-l", "--lang", type=LANGUAGE_RANGE, default="en",
|
||||||
|
@ -243,6 +247,7 @@ class dl:
|
||||||
vbitrate: int,
|
vbitrate: int,
|
||||||
abitrate: int,
|
abitrate: int,
|
||||||
range_: Video.Range,
|
range_: Video.Range,
|
||||||
|
channels: float,
|
||||||
wanted: list[str],
|
wanted: list[str],
|
||||||
lang: list[str],
|
lang: list[str],
|
||||||
v_lang: list[str],
|
v_lang: list[str],
|
||||||
|
@ -370,6 +375,11 @@ class dl:
|
||||||
title.tracks.select_audio(lambda x: x.bitrate and x.bitrate // 1000 == abitrate)
|
title.tracks.select_audio(lambda x: x.bitrate and x.bitrate // 1000 == abitrate)
|
||||||
if not title.tracks.audio:
|
if not title.tracks.audio:
|
||||||
self.log.error(f"There's no {abitrate}kbps Audio Track...")
|
self.log.error(f"There's no {abitrate}kbps Audio Track...")
|
||||||
|
if channels:
|
||||||
|
title.tracks.select_audio(lambda x: math.ceil(x.channels) == math.ceil(channels))
|
||||||
|
if not title.tracks.audio:
|
||||||
|
self.log.error(f"There's no {channels} Audio Track...")
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
if lang and "all" not in lang:
|
if lang and "all" not in lang:
|
||||||
title.tracks.audio = title.tracks.select_per_language(title.tracks.audio, lang)
|
title.tracks.audio = title.tracks.select_per_language(title.tracks.audio, lang)
|
||||||
|
|
Loading…
Reference in New Issue