Browse Source
[downloader/external] Add FFmpegFD(fixes #622)
[downloader/external] Add FFmpegFD(fixes #622)
- replace HlsFD and RtspFD - add basic support for downloading part of the video or audiomaster
4 changed files with 80 additions and 124 deletions
Split View
Diff Options
-
20youtube_dl/downloader/__init__.py
-
65youtube_dl/downloader/external.py
-
74youtube_dl/downloader/hls.py
-
45youtube_dl/downloader/rtsp.py
@ -1,45 +0,0 @@ |
|||
from __future__ import unicode_literals |
|||
|
|||
import os |
|||
import subprocess |
|||
|
|||
from .common import FileDownloader |
|||
from ..utils import ( |
|||
check_executable, |
|||
encodeFilename, |
|||
) |
|||
|
|||
|
|||
class RtspFD(FileDownloader): |
|||
def real_download(self, filename, info_dict): |
|||
url = info_dict['url'] |
|||
self.report_destination(filename) |
|||
tmpfilename = self.temp_name(filename) |
|||
|
|||
if check_executable('mplayer', ['-h']): |
|||
args = [ |
|||
'mplayer', '-really-quiet', '-vo', 'null', '-vc', 'dummy', |
|||
'-dumpstream', '-dumpfile', tmpfilename, url] |
|||
elif check_executable('mpv', ['-h']): |
|||
args = [ |
|||
'mpv', '-really-quiet', '--vo=null', '--stream-dump=' + tmpfilename, url] |
|||
else: |
|||
self.report_error('MMS or RTSP download detected but neither "mplayer" nor "mpv" could be run. Please install any.') |
|||
return False |
|||
|
|||
retval = subprocess.call(args) |
|||
if retval == 0: |
|||
fsize = os.path.getsize(encodeFilename(tmpfilename)) |
|||
self.to_screen('\r[%s] %s bytes' % (args[0], fsize)) |
|||
self.try_rename(tmpfilename, filename) |
|||
self._hook_progress({ |
|||
'downloaded_bytes': fsize, |
|||
'total_bytes': fsize, |
|||
'filename': filename, |
|||
'status': 'finished', |
|||
}) |
|||
return True |
|||
else: |
|||
self.to_stderr('\n') |
|||
self.report_error('%s exited with code %d' % (args[0], retval)) |
|||
return False |
Write
Preview
Loading…
Cancel
Save