cura-te-ipsum/main.py

45 lines
1.5 KiB
Python
Executable File

#!/usr/bin/env python
import argparse
import logging
import os.path
import pathlib
import sys
_lg = logging.getLogger('spqr.curateipsum')
def main():
formatter = logging.Formatter("{asctime}|{levelname}|{message}", style="{")
console_handler = logging.StreamHandler()
console_handler.setFormatter(formatter)
parser = argparse.ArgumentParser(
prog="cura-te-ipsum",
description="cura-te-ipsum, my personal backup software.",
)
parser.add_argument("-V", "--version", action="version", version="%(prog)s 0.1")
parser.add_argument("-v", "--verbose", action="store_true", default=False,
help="print verbose information")
parser.add_argument("-b", type=pathlib.Path, dest="backup_dir",
metavar="BACKUP_DIR", required=True,
help="directory, where all backups will be stored")
parser.add_argument("src_dirs", nargs="+", metavar="SRC_DIR", type=pathlib.Path,
help="directory, which should be backed up")
args = parser.parse_args()
loglevel = logging.DEBUG if args.verbose else logging.INFO
logging.basicConfig(level=loglevel, handlers=[console_handler])
backup_dir_abs = os.path.abspath(args.backup_dir)
if not os.path.isdir(backup_dir_abs):
_lg.error("Backup directory %s does not exist, exiting", args.backup_dir)
return 1
# fs.hardlink_dir(sys.argv[1], sys.argv[2])
# fs.rsync(sys.argv[1], sys.argv[2])
if __name__ == "__main__":
sys.exit(main())