mirror of
https://github.com/samsonjs/vdirsyncer.git
synced 2026-03-28 09:25:50 +00:00
Improve internal apis
This commit is contained in:
parent
76c7f034a7
commit
500de6f081
3 changed files with 13 additions and 6 deletions
|
|
@ -16,8 +16,8 @@ def catch_errors(f):
|
|||
try:
|
||||
f(*a, **kw)
|
||||
except:
|
||||
if not handle_cli_error():
|
||||
sys.exit(1)
|
||||
handle_cli_error()
|
||||
sys.exit(1)
|
||||
|
||||
return inner
|
||||
|
||||
|
|
|
|||
|
|
@ -70,8 +70,8 @@ def sync_collection(wq, pair_name, collection, config_a, config_b,
|
|||
force_delete=force_delete
|
||||
)
|
||||
except:
|
||||
if not handle_cli_error(status_name):
|
||||
raise JobFailed()
|
||||
handle_cli_error(status_name)
|
||||
raise JobFailed()
|
||||
|
||||
save_status(general['status_path'], pair_name, collection,
|
||||
data_type='items', data=status)
|
||||
|
|
|
|||
|
|
@ -44,6 +44,13 @@ class JobFailed(RuntimeError):
|
|||
|
||||
|
||||
def handle_cli_error(status_name='sync'):
|
||||
'''
|
||||
Print a useful error message for the current exception.
|
||||
|
||||
This is supposed to catch all exceptions, and should never raise any
|
||||
exceptions itself.
|
||||
'''
|
||||
|
||||
try:
|
||||
raise
|
||||
except CliError as e:
|
||||
|
|
@ -480,8 +487,8 @@ class WorkerQueue(object):
|
|||
try:
|
||||
func(wq=self)
|
||||
except Exception as e:
|
||||
if not _handle_cli_error():
|
||||
self._exceptions.append(e)
|
||||
_handle_cli_error()
|
||||
self._exceptions.append(e)
|
||||
finally:
|
||||
self._queue.task_done()
|
||||
|
||||
|
|
|
|||
Loading…
Reference in a new issue