135
135
def _args_received(self, args):
136
136
self.expecting = 'body'
137
self.request_handler.args_received(args)
137
self.request_handler.dispatch_command(args[0], args[1:])
138
138
if self.request_handler.finished_reading:
139
139
self._response_sent = True
140
140
self.responder.send_response(self.request_handler.response)
303
303
mutter(' result: %r', self.args)
304
304
if self.status == 'E':
305
305
self._wait_for_response_end()
306
_raise_smart_server_error(self.args)
306
_translate_error(self.args)
307
307
return tuple(self.args)
309
309
def read_body_bytes(self, count=-1):
336
336
self._read_more()
337
337
if self._body_stream_status == 'E':
338
_raise_smart_server_error(self._body_error_args)
338
_translate_error(self._body_error_args)
340
340
def cancel_read_body(self):
341
341
self._wait_for_response_end()
344
def _raise_smart_server_error(error_tuple):
345
"""Raise exception based on tuple received from smart server
347
Specific error translation is handled by bzrlib.remote._translate_error
349
if error_tuple[0] == 'UnknownMethod':
350
raise errors.UnknownSmartMethod(error_tuple[1])
351
raise errors.ErrorFromSmartServer(error_tuple)
344
def _translate_error(error_tuple):
345
# Many exceptions need some state from the requestor to be properly
346
# translated (e.g. they need a branch object). So this only translates a
347
# few errors, and the rest are turned into a generic ErrorFromSmartServer.
348
error_name = error_tuple[0]
349
error_args = error_tuple[1:]
350
if error_name == 'UnknownMethod':
351
raise errors.UnknownSmartMethod(error_args[0])
352
if error_name == 'LockContention':
353
raise errors.LockContention('(remote lock)')
354
elif error_name == 'LockFailed':
355
raise errors.LockFailed(*error_args[:2])
356
elif error_name == 'FileExists':
357
raise errors.FileExists(error_args[0])
358
elif error_name == 'NoSuchFile':
359
raise errors.NoSuchFile(error_args[0])
361
raise errors.ErrorFromSmartServer(error_tuple)