commit: 78da22489b483988e198a8352893df9c6cf34032
parent 557dbac173c30a51acd284b46f2d5460e539f51a
Author: dirkf <fieldhouse@gmx.net>
Date: Wed, 5 Apr 2023 18:39:54 +0100
[compat] Add and use `compat_open()` like Py3 `open()`
* resolves FIXME: ytdl-org/youtube-dl/commit/dfe5fa4
Diffstat:
2 files changed, 13 insertions(+), 4 deletions(-)
diff --git a/youtube_dl/compat.py b/youtube_dl/compat.py
@@ -3127,6 +3127,16 @@ else:
return ctypes.WINFUNCTYPE(*args, **kwargs)
+if sys.version_info < (3, 0):
+ # open(file, mode='r', buffering=- 1, encoding=None, errors=None, newline=None, closefd=True) not: opener=None
+ def compat_open(file_, *args, **kwargs):
+ if len(args) > 6 or 'opener' in kwargs:
+ raise ValueError('open: unsupported argument "opener"')
+ return io.open(file_, *args, **kwargs)
+else:
+ compat_open = open
+
+
legacy = [
'compat_HTMLParseError',
'compat_HTMLParser',
@@ -3185,6 +3195,7 @@ __all__ = [
'compat_kwargs',
'compat_map',
'compat_numeric_types',
+ 'compat_open',
'compat_ord',
'compat_os_name',
'compat_os_path_expanduser',
diff --git a/youtube_dl/options.py b/youtube_dl/options.py
@@ -11,6 +11,7 @@ from .compat import (
compat_get_terminal_size,
compat_getenv,
compat_kwargs,
+ compat_open as open,
compat_shlex_split,
)
from .utils import (
@@ -41,14 +42,11 @@ def _hide_login_info(opts):
def parseOpts(overrideArguments=None):
def _readOptions(filename_bytes, default=[]):
try:
- optionf = open(filename_bytes)
+ optionf = open(filename_bytes, encoding=preferredencoding())
except IOError:
return default # silently skip if file is not present
try:
- # FIXME: https://github.com/ytdl-org/youtube-dl/commit/dfe5fa49aed02cf36ba9f743b11b0903554b5e56
contents = optionf.read()
- if sys.version_info < (3,):
- contents = contents.decode(preferredencoding())
res = compat_shlex_split(contents, comments=True)
finally:
optionf.close()