An open API service indexing awesome lists of open source software.

https://github.com/anmol-singh-jaggi/directsync

:file_folder: :arrows_counterclockwise: :watch: An efficient and easy-to-use utility to compare/synchronize/mirror folder contents.
https://github.com/anmol-singh-jaggi/directsync

backup clone diff directory file mirroring synchronization

Last synced: 2 months ago
JSON representation

:file_folder: :arrows_counterclockwise: :watch: An efficient and easy-to-use utility to compare/synchronize/mirror folder contents.

Awesome Lists containing this project

README

        

# DirectSync

[![PyPI version](https://badge.fury.io/py/directsync.svg)](https://badge.fury.io/py/directsync)
![MIT License](https://img.shields.io/badge/license-MIT-green.svg)
![Blazing fast](https://img.shields.io/badge/speed-blazing%20%F0%9F%94%A5-brightgreen.svg)

[![Say thanks](https://img.shields.io/badge/Say%20Thanks-!-1EAEDB.svg)](https://saythanks.io/to/Anmol-Singh-Jaggi)

A simple and ***fast*** utility to compare/synchronize/mirror folder contents, completely free and open-source*TM*!

**Demo**

![Demo gif](https://github.com/Anmol-Singh-Jaggi/directsync/raw/master/docs/demo.gif)

**Usage:**

directsync [-h] [-add] [-rm] [-ovr] [-mirr] [-trash] [-cache]
[-latest] [-dry] [-no-bar]
src-path dst-path

positional arguments:
src-path The path of the source directory.
dst-path The path of the destination directory.

optional arguments:
-h, --help show this help message and exit
-add, --add-missing Copy files from source which are absent in
destination.
-rm, --remove-extra Remove the files from destination which are absent in
source.
-ovr, --overwrite-content
Overwrite the files having same name but different
content.
-mirr, --mirror-contents
Make the destination directory exactly same as the
source. Shorthand for `-add -rm -ovr`.
-trash, --use-trash Send to trash/recycle bin while deleting/overwriting.
-cache, --use-cache Whether to use previously cached comparison-check
result from disk.
-latest, --preserve-latest
Whether to use the last modified time while
comparing files with different content.
-dry, --dry-run Just simulate and report the file operations that will
be performed with the current configuration.
-no-bar, --hide-progress-bar
Whether to hide the progress bar or not. Will result
in a huge speedup iff the 2 directories are structured
very differently.

**Installation:**
- Install Python 3 (>=3.5)
- `pip install directsync`

**ToDo:**
- Give more fine-tuned control of file comparison algorithm to the user.
- Add `ignore-pattern` option to let the user ignore certain files based on the regex pattern provided.
- Add test cases.
- Add code coverage.
- Setup `tox` and `Travis CI`.
- Add coloured output.
- Handle nested structures with symlinks.
- Provide direct interface with online storage services.
- Add developer guidelines.
- Explore parallel processing.
- Add benchmarks.
- ~~Add demo.~~
- ~~Add `simulate` option.~~
- ~~Add `use-trash` option to send to recycle bin instead of delete/overwrite.~~
- ~~Add `cache` option to cache the results of the previous difference check to disk.~~
- ~~Add `preserve-latest` option: Among the 2 files, the one with the latest modification date should be preserved.~~