Compare commits

..

No commits in common. "a540f4336f6778115cd52b5e9df20bb052dbfd16" and "1beda9d61372a19cbdc63d9e762994d229702cbc" have entirely different histories.

View File

@ -29,12 +29,12 @@ def format_size(n: int) -> str:
return humanfriendly.format_size(n, keep_width=True, binary=True) return humanfriendly.format_size(n, keep_width=True, binary=True)
class Config: class Config:
roots: typing.List[bytes] roots: list[bytes]
max_file_size: typing.Optional[int] max_file_size: typing.Optional[int]
one_file_system: bool one_file_system: bool
exclude_caches: bool exclude_caches: bool
exclude: typing.List[bytes] exclude: list[bytes]
force_include: typing.List[bytes] force_include: list[bytes]
notify_email: typing.Optional[str] notify_email: typing.Optional[str]
def __init__(self, configfile: str): def __init__(self, configfile: str):
@ -93,10 +93,8 @@ class Config:
self.force_include_re = ([ re.compile(x) for x in a ], self.force_include_re = ([ re.compile(x) for x in a ],
[ re.compile(x) for x in b ]) [ re.compile(x) for x in b ])
def match_re(self, def match_re(self, re: tuple[list[typing.Pattern],
re: typing.Tuple[typing.List[typing.Pattern], list[typing.Pattern]], path: bytes):
typing.List[typing.Pattern]],
path: bytes):
# Path matches if it matches at least one regex in # Path matches if it matches at least one regex in
# re[0] and no regex in re[1]. # re[0] and no regex in re[1].
for a in re[0]: for a in re[0]:
@ -111,10 +109,10 @@ class Backup:
def __init__(self, config: Config, dry_run: bool): def __init__(self, config: Config, dry_run: bool):
self.config = config self.config = config
self.dry_run = dry_run self.dry_run = dry_run
self.root_seen: typing.Dict[bytes, bool] = {} self.root_seen: dict[bytes, bool] = {}
# Saved log messages # Saved log messages
self.logs: typing.List[typing.Tuple[str, str]] = [] self.logs: list[tuple[str, str]] = []
def out(self, path: bytes): def out(self, path: bytes):
self.outfile.write(path + (b'\n' if self.dry_run else b'\0')) self.outfile.write(path + (b'\n' if self.dry_run else b'\0'))
@ -229,7 +227,7 @@ class Backup:
self.log('E', f"can't read {pstr(path)}: {str(e)}") self.log('E', f"can't read {pstr(path)}: {str(e)}")
return return
def main(argv: typing.List[str]): def main(argv: list[str]):
import argparse import argparse
def humansize(string): def humansize(string):
@ -277,7 +275,7 @@ def main(argv: typing.List[str]):
backup.log('W', f"failed to parse variables from {args.vars}: {str(e)}") backup.log('W', f"failed to parse variables from {args.vars}: {str(e)}")
# Run backup # Run backup
captured_output: typing.List[bytes] = [] captured_output: list[bytes] = []
if args.dry_run: if args.dry_run:
if args.debug: if args.debug:
@ -311,8 +309,6 @@ def main(argv: typing.List[str]):
# Use a thread to capture output # Use a thread to capture output
def reader_thread(fh): def reader_thread(fh):
nonlocal borg_saw_warnings
nonlocal borg_saw_errors
last_progress = 0 last_progress = 0
for line in fh: for line in fh:
try: try: