Files
server-toolset/many-rsync/explanation.md
Yigid BALABAN a168b4cbea add project tooling and test suite for many-rsync
- Add pyproject.toml: hatchling build, many-rsync entrypoint, ruff/mypy/pytest config
with 60% coverage floor
- Add uv.lock for reproducible dev installs
- Add .pre-commit-config.yaml: ruff (with --fix) + mypy hooks
- Add test_main.py: unit tests for _build_rsync_cmd, _load_raw, and load_config
covering happy paths and FATAL exit cases
- Add explanation.md: architecture overview with flowchart
- main.py: refactor into typed, testable functions (_load_raw, _build_rsync_cmd
extracted); add RsyncParameters/Config TypedDicts; add rsync_parameters config support
(rsync_path, exclude_from); harden validation (n clamped, log_level validated)
- README.md: update install instructions and document all config fields including
rsync_parameters
2026-03-31 22:05:08 +03:00

649 B

explanation

this document shall serve as the explanation for the main.py script. here's the inputs (on the left) and outputs of the script:

flowchart LR
	f["(optional) config file path"] -->|read from passed args| b
	a[sync.toml / sync.json] -->|read input| b[main.py]
	c[local_folders] -->|read input| b
	b -->|rsync folders| d[remote_folder]
	b -->|write logs| e[folder: ~/.rsync-logs/]
  1. If not given explicitly, read config (_load_raw + load_config) and return cfg
  2. Start logging
  3. Fire up the thread pool
    1. run sync_folder for each folder in local_folders against target remote_folder
  4. Log results