Skip to main content

Local file synchronization for scattered shared libraries

Project description

📖 FSync

This tool eliminates the problem of scattered libraries by synchronizing 🔄 selected files spread across different projects on your machine (locally). No more chaos and manual file copying.

At first glance, centralizing libraries seems like a great idea. It makes work easier and avoids code duplication. In practice, however, some complications arise:

  • You don't always want to update a library in a project you're no longer developing, but it still needs to work.
  • Some libraries must be part of the repository. When you hand off/close a project, you want everything in one place, without having to pull additional dependencies from external sources.
  • It's better when all resources are in the project directory. It simplifies configuration (Makefile, CMake), eliminates path and version issues, and improves IDE integration.

This solution is perfect if you run many smaller projects and care about efficient library management (code that appears across multiple projects). If you make frequent changes, want to avoid messy code, but don't have time to spend hours organizing dependencies: this tool is for you! The program is dead simple. What matters is efficient and effective work, without unnecessary bureaucracy. The open source community can do its thing, but here the priority is a happy client and a working project done ⚡fast and 👍good enough.

🧐 Problems!

  • Possible accidental overwrites: if you edit two versions of a library at the same time.
  • ✅ Avoid this, but if it happens, every overwritten version is saved as a timestamped backup, so you can always recover your changes.
  • No environment isolation: different projects may require different versions of the same library.
  • ✅ Not a problem! Just create separate entries for different versions, keeping synchronization independent. You can also comment out entries for libraries that shouldn't be updated anymore.
  • Code duplication across repositories: instead of one library copy, you have several in different projects.
  • ✅ That's the point! Each client should have their own library version, with no dependencies on other repos. Full control, zero unnecessary complications.

🤔 Alternatives?

Of course you can approach this more professionally by:

  • Versioning libraries as separate projects/repositories and updating them as needed.
  • Using Git Submodules, which allows tracking library versions in the repository.
  • External package managers (pip, npm, cargo) that simplify dependency management.

If any of our libraries reach a stable version that we don't chaotically change every project, and they're good enough, it's worth considering one of the above solutions.

⚙️ Config

The sync.json file defines file synchronization configuration. Each entry is a key (filename) and a list of paths to synchronize. Keys starting with # are treated as commented out and skipped.

Paths can use shorthand notation via the dict.ini file, which defines aliases for frequently repeated locations. In sync.json paths you can reference these aliases using {key} notation.

Example

Running the program with the -e, --example flag will create example config files locally.

File dict.ini

web = C:/Users/Me/Projects/WebPage/backend
staff = C:/Users/Me/Desktop/MyStaff/test
work = C:/Users/Me/Work/Drivers/repos

File sync.json

{
  "serial.c": ["{staff}/serial.c", "{work}/PLC/serial_port.c"],
  "utils.py": ["{web}/lib/utils.py", "{work}/PLC/misc.py"],
  "#old_lib.c": ["{staff}/old_lib.c", "{work}/legacy/old_lib.c"]
}

📦 Install

pip install fsync        # basic
pip install fsync[diff]  # + rich (diff display)

Also available as standalone .exe on GitHub Releases.

🚀 Use

First, set the workspace: the directory containing your config files (sync.json, dict.ini) and where backups will be stored:

pyfsync -w C:/Projects/sync  # specified path
pyfsync -w                   # current directory

Running the program generates a report:

pyfsync

To synchronize (i.e. update older file versions), just add the -u, --update flag:

pyfsync -u

For each pair of files with discrepancies, tags are generated. You can use them to inspect differences between files with the -d, --diff flag:

pyfsync -d 1.1

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fsync-1.0.1.tar.gz (9.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fsync-1.0.1-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file fsync-1.0.1.tar.gz.

File metadata

  • Download URL: fsync-1.0.1.tar.gz
  • Upload date:
  • Size: 9.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for fsync-1.0.1.tar.gz
Algorithm Hash digest
SHA256 8f7771d23d90019fc4065ed2000c428531a03f605274e85fc8010bb56efffbd3
MD5 b3ef08d0374fc8d18ce2efefe074ea9b
BLAKE2b-256 ba8022c9fe0cbc2c142f64fd8d3f1976936ae9dd9c570dcf74683c5313559c5b

See more details on using hashes here.

Provenance

The following attestation bundles were made for fsync-1.0.1.tar.gz:

Publisher: publish.yml on Xaeian/FSync

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fsync-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: fsync-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for fsync-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5371c8423db2156a7a2a8726108f82671e7628112a8171561628964fdbd32c51
MD5 c6069b7e60a0a3a0346fa1241e38e9f0
BLAKE2b-256 15bf6b447e171733b7bd12d43f4739155aea5bf22963ee6a99333b6dbc52f78e

See more details on using hashes here.

Provenance

The following attestation bundles were made for fsync-1.0.1-py3-none-any.whl:

Publisher: publish.yml on Xaeian/FSync

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page