diff options
author | pukkandan <pukkandan.ytdlp@gmail.com> | 2023-05-24 23:29:30 +0530 |
---|---|---|
committer | pukkandan <pukkandan.ytdlp@gmail.com> | 2023-05-24 23:29:30 +0530 |
commit | 46f1370e9af6f8af8762f67e27e5acb8f0c48a47 (patch) | |
tree | 3248685f68fdb473ec7e4fdab9447a90e0d82cf6 /devscripts | |
parent | 69a40e4a7f6caa5662527ebd2f3c4e8aa02857a2 (diff) | |
download | hypervideo-pre-46f1370e9af6f8af8762f67e27e5acb8f0c48a47.tar.lz hypervideo-pre-46f1370e9af6f8af8762f67e27e5acb8f0c48a47.tar.xz hypervideo-pre-46f1370e9af6f8af8762f67e27e5acb8f0c48a47.zip |
[devscripts/cli_to_api] Add script
Diffstat (limited to 'devscripts')
-rw-r--r-- | devscripts/cli_to_api.py | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/devscripts/cli_to_api.py b/devscripts/cli_to_api.py new file mode 100644 index 000000000..b8b7cbcf1 --- /dev/null +++ b/devscripts/cli_to_api.py @@ -0,0 +1,48 @@ +# Allow direct execution +import os +import sys + +sys.path.insert(0, os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) + +import yt_dlp +import yt_dlp.options + +create_parser = yt_dlp.options.create_parser + + +def parse_patched_options(opts): + patched_parser = create_parser() + patched_parser.defaults.update({ + 'ignoreerrors': False, + 'retries': 0, + 'fragment_retries': 0, + 'extract_flat': False, + 'concat_playlist': 'never', + }) + yt_dlp.options.__dict__['create_parser'] = lambda: patched_parser + try: + return yt_dlp.parse_options(opts) + finally: + yt_dlp.options.__dict__['create_parser'] = create_parser + + +default_opts = parse_patched_options([]).ydl_opts + + +def cli_to_api(opts, cli_defaults=False): + opts = (yt_dlp.parse_options if cli_defaults else parse_patched_options)(opts).ydl_opts + + diff = {k: v for k, v in opts.items() if default_opts[k] != v} + if 'postprocessors' in diff: + diff['postprocessors'] = [pp for pp in diff['postprocessors'] + if pp not in default_opts['postprocessors']] + return diff + + +if __name__ == '__main__': + from pprint import pprint + + print('\nThe arguments passed translate to:\n') + pprint(cli_to_api(sys.argv[1:])) + print('\nCombining these with the CLI defaults gives:\n') + pprint(cli_to_api(sys.argv[1:], True)) |