mirror of
https://github.com/borgbackup/borg.git
synced 2025-01-02 21:25:26 +00:00
BackupErrors get caught and give warning RCs
also: use more union operators rather than .union()
This commit is contained in:
parent
97dd287584
commit
2e05c234b6
2 changed files with 11 additions and 7 deletions
|
@ -6,12 +6,12 @@
|
||||||
|
|
||||||
import borg.archiver # noqa: F401 - need import to get Error subclasses.
|
import borg.archiver # noqa: F401 - need import to get Error subclasses.
|
||||||
from borg.constants import * # NOQA
|
from borg.constants import * # NOQA
|
||||||
from borg.helpers import Error, BorgWarning
|
from borg.helpers import Error, BackupError, BorgWarning
|
||||||
|
|
||||||
|
|
||||||
def subclasses(cls):
|
def subclasses(cls):
|
||||||
direct_subclasses = cls.__subclasses__()
|
direct_subclasses = cls.__subclasses__()
|
||||||
return set(direct_subclasses).union([s for c in direct_subclasses for s in subclasses(c)])
|
return set(direct_subclasses) | set(s for c in direct_subclasses for s in subclasses(c))
|
||||||
|
|
||||||
|
|
||||||
# 0, 1, 2 are used for success, generic warning, generic error
|
# 0, 1, 2 are used for success, generic warning, generic error
|
||||||
|
@ -25,7 +25,7 @@ def subclasses(cls):
|
||||||
generic_error_rc_classes = set()
|
generic_error_rc_classes = set()
|
||||||
generic_warning_rc_classes = set()
|
generic_warning_rc_classes = set()
|
||||||
|
|
||||||
error_classes = {Error}.union(subclasses(Error))
|
error_classes = {Error} | subclasses(Error)
|
||||||
|
|
||||||
for cls in sorted(error_classes, key=lambda cls: (cls.__module__, cls.__qualname__)):
|
for cls in sorted(error_classes, key=lambda cls: (cls.__module__, cls.__qualname__)):
|
||||||
traceback = "yes" if cls.traceback else "no"
|
traceback = "yes" if cls.traceback else "no"
|
||||||
|
@ -44,7 +44,7 @@ def subclasses(cls):
|
||||||
print("free error RCs:", sorted(free_error_rcs))
|
print("free error RCs:", sorted(free_error_rcs))
|
||||||
print("generic errors:", sorted(generic_error_rc_classes))
|
print("generic errors:", sorted(generic_error_rc_classes))
|
||||||
|
|
||||||
warning_classes = {BorgWarning}.union(subclasses(BorgWarning))
|
warning_classes = {BorgWarning} | subclasses(BorgWarning) | {BackupError} | subclasses(BackupError)
|
||||||
|
|
||||||
for cls in sorted(warning_classes, key=lambda cls: (cls.__module__, cls.__qualname__)):
|
for cls in sorted(warning_classes, key=lambda cls: (cls.__module__, cls.__qualname__)):
|
||||||
rc = cls.exit_mcode
|
rc = cls.exit_mcode
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
modern_ec = os.environ.get("BORG_EXIT_CODES", "legacy") == "modern"
|
modern_ec = os.environ.get("BORG_EXIT_CODES", "legacy") == "modern"
|
||||||
|
|
||||||
|
|
||||||
class Error(Exception):
|
class ErrorBase(Exception):
|
||||||
"""Error: {}"""
|
"""ErrorBase: {}"""
|
||||||
|
|
||||||
# Error base class
|
# Error base class
|
||||||
|
|
||||||
|
@ -37,6 +37,10 @@ def exit_code(self):
|
||||||
return self.exit_mcode if modern_ec else EXIT_ERROR
|
return self.exit_mcode if modern_ec else EXIT_ERROR
|
||||||
|
|
||||||
|
|
||||||
|
class Error(ErrorBase):
|
||||||
|
"""Error: {}"""
|
||||||
|
|
||||||
|
|
||||||
class ErrorWithTraceback(Error):
|
class ErrorWithTraceback(Error):
|
||||||
"""Error: {}"""
|
"""Error: {}"""
|
||||||
|
|
||||||
|
@ -122,7 +126,7 @@ def exit_code(self):
|
||||||
return exc.exit_mcode
|
return exc.exit_mcode
|
||||||
|
|
||||||
|
|
||||||
class BackupError(Error):
|
class BackupError(ErrorBase):
|
||||||
"""{}: backup error"""
|
"""{}: backup error"""
|
||||||
|
|
||||||
# Exception raised for non-OSError-based exceptions while accessing backup files.
|
# Exception raised for non-OSError-based exceptions while accessing backup files.
|
||||||
|
|
Loading…
Reference in a new issue