Skip to main content

bolthole

Project description

bolthole

Automatically backup changes to a directory to git.

Usage

bolthole
    [--ignore GLOB [--ignore ...]]          # autoignored: .git, .gitignore
    [--author AUTHOR] [--message TEXT]      # override your git config
    [--grace SECONDS] [--bundle SECONDS]    # allow for rapid edits to finish
    [--remote NAME [--remote ...]]          # push changes upstream
    [--verbose] [--show-git] [--timeless]
        [--watchdog-debug]                  # control verbosity
    [--dry-run]                             # test it first
    [--once]                                # no ongoing monitoring
    source_dir                              # what to monitor
    [dest_dir]                              # optionally copy to repo

Autocommit a directory

bolthole .

Assumes the directory is already git controlled, and will refuse to start if not. It will commit any outstanding changes. If --once was used, it will then stop, otherwise it will watch for changes until killed, committing them.

Autocommit to a different directory

bolthole project/ pristine-copy/

If pristine-copy doesn't exist, it will copy it and create a git repository there, or it will check that if directory is already git controlled and will refuse to start if not. It will commit any outstanding changes. If --once was used, it will then stop, otherwise it will watch for changes until killed, committing them.

Grace and bundling

The --grace SECONDS option will wait until the amount of time specified has passed before committing the file, and will restart the timer after each change. This way, if a file is being edited repeatedly in a short span of time, the result would be only one commit, not many.

The --bundle SECONDS option allows for multiple file changes to be bundled together in one commit rather than one commit per file, as long as they all happened at roughly the same time. The bundle time is how recently a file needs to have been changed in order to be excluded from the bundle.

For example, with a grace period of five minutes, and a bundle window of one minute:

  • at t = 0m00sfoo.txt is edited, and a timer for it is set for 300 seconds
  • at t = 0m30sbar.txt is edited, and a timer for it is set for 300s (we now have foo.txt at 270s, bar.txt at 300s)
  • at t = 4m30sbaz.txt is edited, and a timer for it is set for 300s (we now have foo.txt at 30s, bar.txt at 60s, baz.txt at 300s)
  • at t = 5m00s — the foo.txt timer goes off (we now have foo.txt at 0s, bar.txt at 30s, baz.txt at 270s); the changes to foo.txt and bar.txt were both made earlier than the bundle window, and one commit is made with both changes
  • at t = 9m30sbaz.txt is committed

Installation

Bolthole is installed from pypi:

pip install bolthole

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

bolthole-1.0.tar.gz (20.0 kB view details)

Uploaded Source

Built Distribution

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

bolthole-1.0-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file bolthole-1.0.tar.gz.

File metadata

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

File hashes

Hashes for bolthole-1.0.tar.gz
Algorithm Hash digest
SHA256 40b8b7f1379e71465743aac6024d1bde35cede192235f0c12a9d46157ae98884
MD5 a12f6aeaabbcc0c70845fab43a96a605
BLAKE2b-256 ba4562e5514a37aaf17c686ac8fb35a8372e86bc6ed4f4011167179ce1792dce

See more details on using hashes here.

Provenance

The following attestation bundles were made for bolthole-1.0.tar.gz:

Publisher: publish.yml on norm/bolthole

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

File details

Details for the file bolthole-1.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for bolthole-1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d7a0a20619d7e181bc76a09533a4af5cf42c1ae57204b1ab2fc5a09923b171dc
MD5 7f2738c385ca4e5e85e8e04cb26ba456
BLAKE2b-256 553b91a1c95c4674de7fbe1c7e86957526bd54dcba9525755cc68495f3da8515

See more details on using hashes here.

Provenance

The following attestation bundles were made for bolthole-1.0-py3-none-any.whl:

Publisher: publish.yml on norm/bolthole

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