Simple tracking of your home directory with easy-to-read diffs.
Project description
Simple home directory versioning
This is a conversion of my simple scripts to version my home directory with very specific excludes and formatting every file upon commit so that readable diffs can be generated.
Installation
pip install baldwin
Usage
$ bw -h
Usage: bw [OPTIONS] COMMAND [ARGS]...
Manage a home directory with Git.
Options:
-d, --debug Enable debug logging.
-h, --help Show this message and exit.
Commands:
auto-commit
format
git
info
init
install-units
In addition to the bw
command, hgit
is a shortcut for bw git
.
Start a new repository
bw init
Find out where the bare Git directory is by running bw info
. This can be done even if init
has
not been run.
Automation
systemd
bw install-units
This will install a timer that will automatically make a new commit every 6 hours. It does not push.
Keep in mind that systemd units require a full path to the executable, so you must keep the unit
up-to-date if you move where you install this package. Simply run bw install-units
again.
Note that user systemd units only run while logged in.
To disable and remove the units, use the following commands:
systemctl disable --now home-vcs.timer
rm ~/.config/systemd/user/home-vcs.*
Pushing
To push, use either of the following:
bw git push
hgit push
The above also demonstrates that bw git
/hgit
are just frontends to git
with the correct
environment applied.
Formatting
If Prettier is installed, it will be used to format files. The configuration used comes with this package. Having consistent formatting allows for nice diffs to be generated.
If you have initialised a repository without having prettier
or jq
in PATH
, you need to run the
following commands to enable readable diffs:
hgit config diff.json.textconv 'jq -MS .'
hgit config diff.json.cachetextconv true
hgit config diff.yaml.textconv 'prettier --no-editorconfig --parser yaml'
hgit config diff.yaml.cachetextconv true
If you have the XML plugin installed:
hgit config diff.xml.textconv 'prettier --no-editorconfig --parser xml --xml-whitespace-sensitivity ignore'
hgit config diff.xml.cachetextconv true
Binary files
Any file that is untracked and detected to be binary will not be added. Use hgit add
to add a
binary file manually.
Other details
Default .gitignore
and .gitattributes
files are installed on initialisation. They are never
modified by this tool. Please customise as necessary.
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
Built Distribution
File details
Details for the file baldwin-0.0.4.tar.gz
.
File metadata
- Download URL: baldwin-0.0.4.tar.gz
- Upload date:
- Size: 9.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.12.1-gentoo-limelight
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | dc8d150e5a23377629877e11fcd9798a04688ba31f29db29dd797b9d8f1562cb |
|
MD5 | 75a58ca978600d04951fa5686c50f309 |
|
BLAKE2b-256 | 6e062d255a7ec9a73abd2d994e6c5b807c2f4288aa3bab3051583c16b4170a7d |
File details
Details for the file baldwin-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: baldwin-0.0.4-py3-none-any.whl
- Upload date:
- Size: 8.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.12.1-gentoo-limelight
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f5646fa9fbb2b36de75e121c5188a5559bd7773d89292dcb79b9547d217dfea5 |
|
MD5 | cb311365875784c46714a82c08279186 |
|
BLAKE2b-256 | df5ce693236030f1099e4691b00345f7d875369d53e8fd2f96a5e2f2f3f2b941 |