diff options
Diffstat (limited to 'youtube_dl/downloader/rtmp.py')
| -rw-r--r-- | youtube_dl/downloader/rtmp.py | 48 | 
1 files changed, 23 insertions, 25 deletions
| diff --git a/youtube_dl/downloader/rtmp.py b/youtube_dl/downloader/rtmp.py index f7eeb6f43..14d56db47 100644 --- a/youtube_dl/downloader/rtmp.py +++ b/youtube_dl/downloader/rtmp.py @@ -3,7 +3,6 @@ from __future__ import unicode_literals  import os  import re  import subprocess -import sys  import time  from .common import FileDownloader @@ -11,7 +10,7 @@ from ..compat import compat_str  from ..utils import (      check_executable,      encodeFilename, -    format_bytes, +    encodeArgument,      get_exe_version,  ) @@ -51,23 +50,23 @@ class RtmpFD(FileDownloader):                      if not resume_percent:                          resume_percent = percent                          resume_downloaded_data_len = downloaded_data_len -                    eta = self.calc_eta(start, time.time(), 100 - resume_percent, percent - resume_percent) -                    speed = self.calc_speed(start, time.time(), downloaded_data_len - resume_downloaded_data_len) +                    time_now = time.time() +                    eta = self.calc_eta(start, time_now, 100 - resume_percent, percent - resume_percent) +                    speed = self.calc_speed(start, time_now, downloaded_data_len - resume_downloaded_data_len)                      data_len = None                      if percent > 0:                          data_len = int(downloaded_data_len * 100 / percent) -                    data_len_str = '~' + format_bytes(data_len) -                    self.report_progress(percent, data_len_str, speed, eta) -                    cursor_in_new_line = False                      self._hook_progress({ +                        'status': 'downloading',                          'downloaded_bytes': downloaded_data_len, -                        'total_bytes': data_len, +                        'total_bytes_estimate': data_len,                          'tmpfilename': tmpfilename,                          'filename': filename, -                        'status': 'downloading',                          'eta': eta, +                        'elapsed': time_now - start,                          'speed': speed,                      }) +                    cursor_in_new_line = False                  else:                      # no percent for live streams                      mobj = re.search(r'([0-9]+\.[0-9]{3}) kB / [0-9]+\.[0-9]{2} sec', line) @@ -75,15 +74,15 @@ class RtmpFD(FileDownloader):                          downloaded_data_len = int(float(mobj.group(1)) * 1024)                          time_now = time.time()                          speed = self.calc_speed(start, time_now, downloaded_data_len) -                        self.report_progress_live_stream(downloaded_data_len, speed, time_now - start) -                        cursor_in_new_line = False                          self._hook_progress({                              'downloaded_bytes': downloaded_data_len,                              'tmpfilename': tmpfilename,                              'filename': filename,                              'status': 'downloading', +                            'elapsed': time_now - start,                              'speed': speed,                          }) +                        cursor_in_new_line = False                      elif self.params.get('verbose', False):                          if not cursor_in_new_line:                              self.to_screen('') @@ -106,7 +105,7 @@ class RtmpFD(FileDownloader):          protocol = info_dict.get('rtmp_protocol', None)          real_time = info_dict.get('rtmp_real_time', False)          no_resume = info_dict.get('no_resume', False) -        continue_dl = info_dict.get('continuedl', False) +        continue_dl = self.params.get('continuedl', True)          self.report_destination(filename)          tmpfilename = self.temp_name(filename) @@ -118,9 +117,11 @@ class RtmpFD(FileDownloader):              return False          # Download using rtmpdump. rtmpdump returns exit code 2 when -        # the connection was interrumpted and resuming appears to be +        # the connection was interrupted and resuming appears to be          # possible. This is part of rtmpdump's normal usage, AFAIK. -        basic_args = ['rtmpdump', '--verbose', '-r', url, '-o', tmpfilename] +        basic_args = [ +            'rtmpdump', '--verbose', '-r', url, +            '-o', tmpfilename]          if player_url is not None:              basic_args += ['--swfVfy', player_url]          if page_url is not None: @@ -130,7 +131,7 @@ class RtmpFD(FileDownloader):          if play_path is not None:              basic_args += ['--playpath', play_path]          if tc_url is not None: -            basic_args += ['--tcUrl', url] +            basic_args += ['--tcUrl', tc_url]          if test:              basic_args += ['--stop', '1']          if flash_version is not None: @@ -153,16 +154,9 @@ class RtmpFD(FileDownloader):          if not live and continue_dl:              args += ['--skip', '1'] -        if sys.platform == 'win32' and sys.version_info < (3, 0): -            # Windows subprocess module does not actually support Unicode -            # on Python 2.x -            # See http://stackoverflow.com/a/9951851/35070 -            subprocess_encoding = sys.getfilesystemencoding() -            args = [a.encode(subprocess_encoding, 'ignore') for a in args] -        else: -            subprocess_encoding = None +        args = [encodeArgument(a) for a in args] -        self._debug_cmd(args, subprocess_encoding, exe='rtmpdump') +        self._debug_cmd(args, exe='rtmpdump')          RD_SUCCESS = 0          RD_FAILED = 1 @@ -179,7 +173,11 @@ class RtmpFD(FileDownloader):              prevsize = os.path.getsize(encodeFilename(tmpfilename))              self.to_screen('[rtmpdump] %s bytes' % prevsize)              time.sleep(5.0)  # This seems to be needed -            retval = run_rtmpdump(basic_args + ['-e'] + [[], ['-k', '1']][retval == RD_FAILED]) +            args = basic_args + ['--resume'] +            if retval == RD_FAILED: +                args += ['--skip', '1'] +            args = [encodeArgument(a) for a in args] +            retval = run_rtmpdump(args)              cursize = os.path.getsize(encodeFilename(tmpfilename))              if prevsize == cursize and retval == RD_FAILED:                  break | 
