mirror of
https://github.com/yt-dlp/yt-dlp.git
synced 2024-11-27 14:14:54 +01:00
e625be0d10
* Allow slicing lists/strings using `field.start🔚step`
* A field can also be used as offset like `field1+num+field2`
* A default value can be given using `field|default`
* Capture all format strings and set it to `None` if invalid. This prevents invalid fields from causing errors
42 lines
1.2 KiB
Python
42 lines
1.2 KiB
Python
from __future__ import unicode_literals
|
|
|
|
import re
|
|
import subprocess
|
|
|
|
from .common import PostProcessor
|
|
from ..compat import compat_shlex_quote
|
|
from ..utils import (
|
|
encodeArgument,
|
|
FORMAT_RE,
|
|
PostProcessingError,
|
|
)
|
|
|
|
|
|
class ExecAfterDownloadPP(PostProcessor):
|
|
|
|
def __init__(self, downloader, exec_cmd):
|
|
super(ExecAfterDownloadPP, self).__init__(downloader)
|
|
self.exec_cmd = exec_cmd
|
|
|
|
@classmethod
|
|
def pp_key(cls):
|
|
return 'Exec'
|
|
|
|
def parse_cmd(self, cmd, info):
|
|
# If no %(key)s is found, replace {} for backard compatibility
|
|
if not re.search(FORMAT_RE.format(r'[^)]*'), cmd):
|
|
if '{}' not in cmd:
|
|
cmd += ' {}'
|
|
return cmd.replace('{}', compat_shlex_quote(info['filepath']))
|
|
|
|
tmpl, info_copy = self._downloader.prepare_outtmpl(cmd, info)
|
|
return tmpl % info_copy
|
|
|
|
def run(self, info):
|
|
cmd = self.parse_cmd(self.exec_cmd, info)
|
|
self.to_screen('Executing command: %s' % cmd)
|
|
retCode = subprocess.call(encodeArgument(cmd), shell=True)
|
|
if retCode != 0:
|
|
raise PostProcessingError('Command returned error code %d' % retCode)
|
|
return [], info
|