feat(node-sub): improve support for series
All checks were successful
Discord / discord commits (push) Has been skipped
All checks were successful
Discord / discord commits (push) Has been skipped
This commit is contained in:
parent
d625b740be
commit
b7b25ea3cc
1 changed files with 105 additions and 99 deletions
|
@ -21,11 +21,12 @@ const SPAWN_OPTS = {
|
||||||
* @param languages a comma-separated list of languages (3 letters) to sync the subtitles
|
* @param languages a comma-separated list of languages (3 letters) to sync the subtitles
|
||||||
*/
|
*/
|
||||||
const DIR = process.argv[2];
|
const DIR = process.argv[2];
|
||||||
let langs = process.argv[3].split(',');
|
const LANGS = process.argv[3]?.split(',');
|
||||||
|
let langs: string[];
|
||||||
|
|
||||||
|
|
||||||
// Check if there are 2 params
|
// Check if there are 2 params
|
||||||
if (DIR && langs) {
|
if (DIR && LANGS) {
|
||||||
main();
|
main();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -33,9 +34,9 @@ else {
|
||||||
process.exit(1);
|
process.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
const escapePath = (p: string) => p.replaceAll("'", "'\\''");
|
const escapePath = (p: string): string => p.replaceAll("'", "'\\''");
|
||||||
|
|
||||||
function getVideoPath(files: string[]) {
|
function getVideoPath(files: string[]): string[] {
|
||||||
const fileName = DIR.split('/').at(-1) ?? '';
|
const fileName = DIR.split('/').at(-1) ?? '';
|
||||||
|
|
||||||
const videoFiles = files.filter((f) =>
|
const videoFiles = files.filter((f) =>
|
||||||
|
@ -46,10 +47,10 @@ function getVideoPath(files: string[]) {
|
||||||
process.exit(0);
|
process.exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
return `${DIR}/${videoFiles[0]}`;
|
return videoFiles.map((file) => `${DIR}/${file}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
async function backupSubs(files: string[]) {
|
async function backupSubs(files: string[], base: string) {
|
||||||
// Check if backup folder already exists and create it if not
|
// Check if backup folder already exists and create it if not
|
||||||
if (!files.some((f) => f.endsWith('.srt.bak'))) {
|
if (!files.some((f) => f.endsWith('.srt.bak'))) {
|
||||||
await mkdir(`${DIR}/.srt.bak`);
|
await mkdir(`${DIR}/.srt.bak`);
|
||||||
|
@ -60,7 +61,9 @@ async function backupSubs(files: string[]) {
|
||||||
|
|
||||||
// Remove synced subtitles from the list to sync
|
// Remove synced subtitles from the list to sync
|
||||||
// langs - backups
|
// langs - backups
|
||||||
langs = langs.filter((n) => !backups
|
langs = langs
|
||||||
|
.filter((n) => !backups
|
||||||
|
.filter((l) => l.includes(base))
|
||||||
.some((s) => {
|
.some((s) => {
|
||||||
const l2 = s.split('.').at(-2) ?? '';
|
const l2 = s.split('.').at(-2) ?? '';
|
||||||
const l3 = ISO6391To3.get(l2);
|
const l3 = ISO6391To3.get(l2);
|
||||||
|
@ -70,8 +73,7 @@ async function backupSubs(files: string[]) {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (langs.length === 0) {
|
if (langs.length === 0) {
|
||||||
console.warn('Subtitles have already been synced');
|
console.warn(`Subtitles have already been synced for ${base}`);
|
||||||
process.exit(0);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -93,18 +95,20 @@ async function runSubSync(
|
||||||
async function main() {
|
async function main() {
|
||||||
const files = await readDir(DIR);
|
const files = await readDir(DIR);
|
||||||
|
|
||||||
const VIDEO = getVideoPath(files);
|
const VIDEO_FILES = getVideoPath(files);
|
||||||
const BASE_NAME = VIDEO.split('/').at(-1)?.replace(/\.[^.]*$/, '');
|
|
||||||
|
|
||||||
backupSubs(files);
|
VIDEO_FILES.forEach((VIDEO) => {
|
||||||
|
langs = LANGS;
|
||||||
|
const BASE_NAME = VIDEO.split('/').at(-1)!.replace(/\.[^.]*$/, '');
|
||||||
|
|
||||||
|
backupSubs(files, BASE_NAME);
|
||||||
|
|
||||||
// ffprobe the video file to see available audio tracks
|
// ffprobe the video file to see available audio tracks
|
||||||
ffProbe(VIDEO, (_e, data) => {
|
ffProbe(VIDEO, (_e, data) => {
|
||||||
if (!data?.streams) {
|
if (!data?.streams) {
|
||||||
console.error('Couldn\'t find streams in video file');
|
console.error('Couldn\'t find streams in video file');
|
||||||
process.exit(0);
|
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
const AVAIL_LANGS = data.streams
|
const AVAIL_LANGS = data.streams
|
||||||
.filter((s) => s.codec_type === 'audio')
|
.filter((s) => s.codec_type === 'audio')
|
||||||
.map((s) => s['tags'] && s['tags']['language']);
|
.map((s) => s['tags'] && s['tags']['language']);
|
||||||
|
@ -186,5 +190,7 @@ async function main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue