mirror of
https://github.com/kkroening/ffmpeg-python.git
synced 2025-04-05 04:22:51 +08:00
Use fspath to fully support PathLike objects.
PathLike objects were already implicitly supported by `input` and by `output` when the filename was explicitly specified as a keyword argument. However, implicitly setting the output filename from a list of output streams/filename did not permit a PathLike object.
This commit is contained in:
parent
df129c7ba3
commit
59c504c531
@ -1,7 +1,7 @@
|
|||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
from past.builtins import basestring
|
from past.builtins import basestring
|
||||||
from ._utils import basestring
|
from ._utils import basestring, fspath
|
||||||
|
|
||||||
from .nodes import (
|
from .nodes import (
|
||||||
filter_operator,
|
filter_operator,
|
||||||
@ -23,7 +23,7 @@ def input(filename, **kwargs):
|
|||||||
|
|
||||||
Official documentation: `Main options <https://ffmpeg.org/ffmpeg.html#Main-options>`__
|
Official documentation: `Main options <https://ffmpeg.org/ffmpeg.html#Main-options>`__
|
||||||
"""
|
"""
|
||||||
kwargs['filename'] = filename
|
kwargs['filename'] = fspath(filename)
|
||||||
fmt = kwargs.pop('f', None)
|
fmt = kwargs.pop('f', None)
|
||||||
if fmt:
|
if fmt:
|
||||||
if 'format' in kwargs:
|
if 'format' in kwargs:
|
||||||
@ -79,9 +79,12 @@ def output(*streams_and_filename, **kwargs):
|
|||||||
"""
|
"""
|
||||||
streams_and_filename = list(streams_and_filename)
|
streams_and_filename = list(streams_and_filename)
|
||||||
if 'filename' not in kwargs:
|
if 'filename' not in kwargs:
|
||||||
if not isinstance(streams_and_filename[-1], basestring):
|
# Raise any errors without destructively modifying streams_and_filenames
|
||||||
|
try:
|
||||||
|
fspath(streams_and_filename[-1])
|
||||||
|
except TypeError:
|
||||||
raise ValueError('A filename must be provided')
|
raise ValueError('A filename must be provided')
|
||||||
kwargs['filename'] = streams_and_filename.pop(-1)
|
kwargs['filename'] = fspath(streams_and_filename.pop(-1))
|
||||||
streams = streams_and_filename
|
streams = streams_and_filename
|
||||||
|
|
||||||
fmt = kwargs.pop('f', None)
|
fmt = kwargs.pop('f', None)
|
||||||
|
@ -106,3 +106,38 @@ def convert_kwargs_to_cmd_line_args(kwargs):
|
|||||||
if v is not None:
|
if v is not None:
|
||||||
args.append('{}'.format(v))
|
args.append('{}'.format(v))
|
||||||
return args
|
return args
|
||||||
|
|
||||||
|
|
||||||
|
if sys.version_info >= (3, 6):
|
||||||
|
from os import fspath
|
||||||
|
else:
|
||||||
|
# This code is mostly copy-pasted from PEP 519, with (str, bytes) instance
|
||||||
|
# checks converted to basestring instance checks.
|
||||||
|
def fspath(path):
|
||||||
|
"""Return the string representation of the path.
|
||||||
|
|
||||||
|
If str or bytes is passed in, it is returned unchanged. If __fspath__()
|
||||||
|
returns something other than str or bytes then TypeError is raised. If
|
||||||
|
this function is given something that is not str, bytes, or os.PathLike
|
||||||
|
then TypeError is raised.
|
||||||
|
"""
|
||||||
|
if isinstance(path, basestring):
|
||||||
|
return path
|
||||||
|
|
||||||
|
# Work from the object's type to match method resolution of other magic
|
||||||
|
# methods.
|
||||||
|
path_type = type(path)
|
||||||
|
try:
|
||||||
|
path = path_type.__fspath__(path)
|
||||||
|
except AttributeError:
|
||||||
|
if hasattr(path_type, '__fspath__'):
|
||||||
|
raise
|
||||||
|
else:
|
||||||
|
if isinstance(path, basestring):
|
||||||
|
return path
|
||||||
|
else:
|
||||||
|
raise TypeError("expected __fspath__() to return str or bytes, "
|
||||||
|
"not " + type(path).__name__)
|
||||||
|
|
||||||
|
raise TypeError("expected str, bytes or os.PathLike object, not "
|
||||||
|
+ path_type.__name__)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user