|
|
2 years ago | |
|---|---|---|
| src/transpose | 2 years ago | |
| tests | 2 years ago | |
| .flake8 | 3 years ago | |
| .gitignore | 2 years ago | |
| .pre-commit-config.yaml | 2 years ago | |
| CHANGELOG.md | 3 years ago | |
| LICENSE | 3 years ago | |
| README.md | 2 years ago | |
| poetry.lock | 2 years ago | |
| pyproject.toml | 2 years ago | |
A tool for moving and symlinking directories to a central location
I've been using linux as my main machine for a while and wanted a central directory to backup as backing up my entire HOME directory was a mess. I found moving directories and symlinking worked great. I created a simple project when learning python (I called symlinker) and used it for a while but found it annoying to configure and work with.
I recently found I could use a tool like this for a SteamDeck and decided to start from scratch with better code and easier to use.
This is the current result, although it still needs a lot of work as I'm sure I'm not doing things particularly well.
Additionally, the name transpose was sort of chosen at random and has no particular meaning currently. I'd like to change it in the future but haven't really come up with any suitable replacement.
Can be installed via pip. For instance, from within a virtualenv:
python -m venv .venv
. .venv/bin/activate
pip install .
transpose store ~/.config/zsh # Move ~/.config/zsh -> ~/.local/share/transpose/zsh, create symlink, create cache
transpose restore zsh # Remove symlink, move ~/.local/share/transpose/zsh_config -> ~/.config/zsh, remove cache
transpose apply zsh # Recreate symlink in store path (useful after moving Store Path location)
transpose store -s /mnt/backups ~/.config/zsh zsh_config # Move ~/.config/zsh -> /mnt/backups/zsh_config, create symlink
See transpose --help for more information on each comment
Storing a directory will:
target to $STORE_PATH/{name}target to $STORE_PATH/{name}$STORE_PATH/{name}/.transpose.json to store the original target pathtranspose store /home/user/Documents "My Documents"
The above will (assuming using all the defaults):
/home/user/Documents to $XDG_DATA_HOME/transpose/My Documents/home/user/Documents to $XDG_DATA_HOME/transpose/My DocumentsNote: The name on the end (My Documents above), can be ommitted. The stored name will use the target name (e.g. Documents above)
Restoring a directory will:
original_path of the cache file, $STORE_PATH/{name}/.transpose.jsonoriginal_pathtranspose restore Game1
The above will (assuming all the defaults):
/home/user/Documents/games/MyGame (from settings file)$XDG_DATA_HOME/transpose/Game1 to /home/user/Documents/games/MyGameThis will recreate the symlink based on the config file within the directory.
This is most useful when moving the stored directory.
transpose apply "Game1"
It's possible to modify the tranpose configuration file, STORE_PATH/transpose.json, using the console:
transpose config add "NewEntry" "/path/to/location"
transpose config get "NewEntry"
transpose config list
transpose config remove "NewEntry"
poetry install
poetry add --dev black
poetry update # Only to update to latest versions, update poetry.lock
poetry run python src/transpose/console.py
poetry run pytest --cov=transpose --cov-report html tests
poetry shell