Compare commits
No commits in common. "a540f4336f6778115cd52b5e9df20bb052dbfd16" and "1beda9d61372a19cbdc63d9e762994d229702cbc" have entirely different histories.
a540f4336f
...
1beda9d613
22
backup.py
22
backup.py
|
@ -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:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user