]> git.frykholm.com Git - svtplaydump.git/commitdiff
Connection reset fix
authorMikael Frykholm <mikael@frykholm.com>
Wed, 20 Nov 2013 07:27:06 +0000 (08:27 +0100)
committerMikael Frykholm <mikael@frykholm.com>
Wed, 20 Nov 2013 07:27:06 +0000 (08:27 +0100)
Better handling if a connection is reset.

svtplaydump.py

index 39bc9ff8edba82f6a0250e6bbd706c1daad319ba..05ea3f842d75a6c330eeae214c647d1749c51c35 100755 (executable)
@@ -30,6 +30,7 @@ import struct
 import argparse
 import requests
 import sys, os
 import argparse
 import requests
 import sys, os
+import socket
 
 class Video(dict):
     def __init__(self, *args, **kwargs):
 
 class Video(dict):
     def __init__(self, *args, **kwargs):
@@ -106,13 +107,18 @@ def download_from_playlist(video):
         size = 0
         for url in segments:
             ufile = requests.get(url, stream=True).raw
         size = 0
         for url in segments:
             ufile = requests.get(url, stream=True).raw
-            print("\r{0:.2f} MB".format(size/1024/1024))
+            print("\r{0:.2f} MB".format(size/1024/1024),end="")
             sys.stdout.flush()
             if decrypt:
                 iv=struct.pack("IIII",segment,0,0,0)
                 decryptor = AES.new(key, AES.MODE_CBC, iv)
             while(True):
             sys.stdout.flush()
             if decrypt:
                 iv=struct.pack("IIII",segment,0,0,0)
                 decryptor = AES.new(key, AES.MODE_CBC, iv)
             while(True):
-                buf = ufile.read(4096)
+                try:
+                    buf = ufile.read(4096)
+                except socket.error as e:
+                    print("Error reading, skipping file")
+                    print(e)
+                    return
                 if not buf:
                     break
                 if decrypt:
                 if not buf:
                     break
                 if decrypt: