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 | ||
