diff options
-rw-r--r-- | subcmds/sync.py | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/subcmds/sync.py b/subcmds/sync.py index 507d1c94..a2b376bc 100644 --- a/subcmds/sync.py +++ b/subcmds/sync.py | |||
@@ -28,6 +28,7 @@ import time | |||
28 | import urllib.error | 28 | import urllib.error |
29 | import urllib.parse | 29 | import urllib.parse |
30 | import urllib.request | 30 | import urllib.request |
31 | import xml.parsers.expat | ||
31 | import xmlrpc.client | 32 | import xmlrpc.client |
32 | 33 | ||
33 | try: | 34 | try: |
@@ -1431,11 +1432,16 @@ class PersistentTransport(xmlrpc.client.Transport): | |||
1431 | raise | 1432 | raise |
1432 | 1433 | ||
1433 | p, u = xmlrpc.client.getparser() | 1434 | p, u = xmlrpc.client.getparser() |
1434 | while 1: | 1435 | # Response should be fairly small, so read it all at once. |
1435 | data = response.read(1024) | 1436 | # This way we can show it to the user in case of error (e.g. HTML). |
1436 | if not data: | 1437 | data = response.read() |
1437 | break | 1438 | try: |
1438 | p.feed(data) | 1439 | p.feed(data) |
1440 | except xml.parsers.expat.ExpatError as e: | ||
1441 | raise IOError( | ||
1442 | f'Parsing the manifest failed: {e}\n' | ||
1443 | f'Please report this to your manifest server admin.\n' | ||
1444 | f'Here is the full response:\n{data.decode("utf-8")}') | ||
1439 | p.close() | 1445 | p.close() |
1440 | return u.close() | 1446 | return u.close() |
1441 | 1447 | ||