import os
import os.path as osp
from multiprocessing import Pool
import subprocess
from functools import partial

def run_ep(ep_folder, source_pattern='_source.mp4', target_pattern='_target.mp4', names=['a', 'b', 'c']):
    fns = os.listdir(ep_folder)
    for fn in fns:
        if source_pattern in fn and fn.replace(source_pattern, '') in names:
            if fn.replace(source_pattern, target_pattern) in fns:
                continue

            fp = osp.join(ep_folder, fn)
            tar = osp.join(ep_folder, fn.replace(source_pattern, target_pattern))

            cmd = f'ffmpeg -i {fp} -r 30 -s 256x192 -c:v libx265 -crf 24 -g 8 -keyint_min 8 -sc_threshold 0 -vf "setpts=N/(30*TB)" -bf 0 -c:a copy {tar} -y'
            os.system(cmd)

def main(root='/path/to/dataset/', num_workers=-1):
    ep_folders = list(map(lambda x: osp.join(root, x), os.listdir(root)))
    if num_workers == -1:
        num_workers = int(os.cpu_count() * 0.8)
    else:
        num_workers = num_workers
    with Pool(num_workers) as p:
        p.map(run_ep, ep_folders)

# --------------------------------------------------------------- #

def run_video(fp, source_pattern='.mp4', target_pattern='_target.mp4'):
    tar = fp.replace(source_pattern, target_pattern)
    if osp.exists(tar):
        return
    cmd = f'ffmpeg -i {fp} -r 30 -s 256x192 -c:v libx265 -crf 24 -g 8 -keyint_min 8 -sc_threshold 0 -vf "setpts=N/(30*TB)" -bf 0 -c:a copy {tar} -y'
    os.system(cmd)

def main_anonymous(root='/path/to/another_dataset', num_workers=-1):
    # Ownership change command removed for anonymization

    all_files = []
    for curr_dir, sub_dir, files in os.walk(root):
        if 'a_source.mp4' in files:
            for filename in files:
                all_files.append(osp.join(curr_dir, filename))

    if num_workers == -1:
        num_workers = int(os.cpu_count() * 0.8)
    else:
        num_workers = num_workers
    with Pool(num_workers) as p:
        p.map(run_video, all_files)

if __name__ == '__main__':
    import fire
    fire.Fire(main_anonymous)