from __future__ import unicode_literals from .nodes import ( filter_operator, GlobalNode, InputNode, MergeOutputsNode, OutputNode, output_operator, SourceNode) def input(filename, **kwargs): """Input file URL (ffmpeg ``-i`` option) Official documentation: `Main options `__ """ kwargs['filename'] = filename fmt = kwargs.pop('f', None) if fmt: if 'format' in kwargs: raise ValueError("Can't specify both `format` and `f` kwargs") kwargs['format'] = fmt return InputNode(input.__name__, kwargs=kwargs).stream() def source_multi_output(filter_name, *args, **kwargs): """Source filter with one or more outputs. This is the same as ``source`` except that the filter can produce more than one output. To reference an output stream, use either the ``.stream`` operator or bracket shorthand. """ return SourceNode(filter_name, args=args, kwargs=kwargs) def source(filter_name, *args, **kwargs): """Source filter. It works like `input`, but takes a source filter name instead of a file URL as the first argument. Official documentation: `Sources `__ """ return source_multi_output(filter_name, *args, **kwargs).stream() @output_operator() def overwrite_output(stream): """Overwrite output files without asking (ffmpeg ``-y`` option) Official documentation: `Main options `__ """ return GlobalNode(stream, overwrite_output.__name__).stream() @output_operator() def merge_outputs(*streams): """Include all given outputs in one ffmpeg command line """ return MergeOutputsNode(streams, merge_outputs.__name__).stream() @filter_operator() def output(stream, filename, **kwargs): """Output file URL Official documentation: `Synopsis `__ """ kwargs['filename'] = filename fmt = kwargs.pop('f', None) if fmt: if 'format' in kwargs: raise ValueError("Can't specify both `format` and `f` kwargs") kwargs['format'] = fmt return OutputNode(stream, output.__name__, kwargs=kwargs).stream() __all__ = [ 'input', 'source_multi_output', 'source', 'merge_outputs', 'output', 'overwrite_output', ]