diff options
author | Philipp Hagemeister <phihag@phihag.de> | 2013-12-23 05:03:32 +0100 |
---|---|---|
committer | Philipp Hagemeister <phihag@phihag.de> | 2013-12-23 05:03:32 +0100 |
commit | 9fc3bef87a1009eb48f2012f3eab65761a53ba5e (patch) | |
tree | a8f80150af91bc2c749116b80fb314fffefd432c /youtube_dl/downloader/mplayer.py | |
parent | d80044c235afcbcfa905ab08a82f6f972df25268 (diff) | |
parent | 3bc2ddccc8622379ec11e802dff30a635285a9c8 (diff) |
Merge remote-tracking branch 'jaimeMF/split-downloaders'
Diffstat (limited to 'youtube_dl/downloader/mplayer.py')
-rw-r--r-- | youtube_dl/downloader/mplayer.py | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/youtube_dl/downloader/mplayer.py b/youtube_dl/downloader/mplayer.py new file mode 100644 index 000000000..7dd6e76d0 --- /dev/null +++ b/youtube_dl/downloader/mplayer.py @@ -0,0 +1,39 @@ +import os +import subprocess + +from .common import FileDownloader +from ..utils import ( + encodeFilename, +) + + +class MplayerFD(FileDownloader): + def real_download(self, filename, info_dict): + self.report_destination(filename) + tmpfilename = self.temp_name(filename) + + args = ['mplayer', '-really-quiet', '-vo', 'null', '-vc', 'dummy', '-dumpstream', '-dumpfile', tmpfilename, url] + # Check for mplayer first + try: + subprocess.call(['mplayer', '-h'], stdout=(open(os.path.devnull, 'w')), stderr=subprocess.STDOUT) + except (OSError, IOError): + self.report_error(u'MMS or RTSP download detected but "%s" could not be run' % args[0] ) + return False + + # Download using mplayer. + retval = subprocess.call(args) + if retval == 0: + fsize = os.path.getsize(encodeFilename(tmpfilename)) + self.to_screen(u'\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(u"\n") + self.report_error(u'mplayer exited with code %d' % retval) + return False |