Personal dotfiles. The installation supports Arch and Debian based systems.
Find a file
2020-09-05 19:11:03 +02:00
dotfiles Tidy up a bit 2020-09-05 19:11:03 +02:00
git_hooks Change hook to include remote else we loose it in git log 2020-09-03 17:21:13 +02:00
pacman_hooks Move borg backup script out of pacman_hooks, set Exec line in corresponding hook accordingly 2020-09-05 13:13:03 +02:00
.gitignore Add secrets to .gitignore 2020-09-05 18:11:51 +02:00
arch-desktop_borg.sh Move borg backup script out of pacman_hooks, set Exec line in corresponding hook accordingly 2020-09-05 13:13:03 +02:00
firefox_addons.txt Add list of firefox addons 2020-06-12 12:34:53 +02:00
install.py Cancel decorator 2020-09-05 16:45:07 +02:00
README.md Add instruction to README 2020-09-05 15:02:01 +02:00
requirements.txt Add path 2020-04-18 21:05:02 +02:00
shellcheck_binary_fix.sh Update shellcheck binary url 2020-09-05 11:11:31 +02:00
symlink_git_hooks.sh Add messages to symlink script 2020-09-05 12:12:48 +02:00
todo Cancel decorator 2020-09-05 16:45:07 +02:00

Getting started

The Python requirements are all in requirements.txt, so before starting you need to issue the following command:

$ pip install -r requirements.txt --user

without using sudo. Using sudo with pip is a bad idea because it will interfere with your distribution's package manager.

If on a fresh install, you won't have pip installed, so you'll need:

$ sudo pacman -S python-pip

or

$ sudo apt install python3-pip

Then run ./install.py with needed flags (./install.py -h is your friend).

About the files in the repo

  • arch-desktop_borg.sh
    Borg backup script. Used by a pacman hook to backup my system.

  • configs.yml
    Lists the things to install, which includes programs, symlinks, git clones, shell commands...

  • dotfiles/
    The actual dotfiles. They are symlinked to the location that the system expects to find them.

  • git_hooks/
    See symlink_git_hooks.sh.

  • install.py
    Installs everything using configs.yml. This is the file to actually run.

  • firefox_addons.txt
    I like to install my Firefox add-ons manually in the Firefox add-on manager, so this file just reminds me what to install and includes the urls to each add-on.

  • pacman_hooks/
    You need to manually copy or symlink any hook to /etc/pacman.d/hooks/ to activate it.

  • shellcheck_binary_fix.sh
    When running this on Manjaro, pacman was unable to find the shellcheck package, so this script installs the pre-compiled binary instead. If your package manager finds shellcheck, this script won't run.

  • symlink_git_hooks.sh
    Helper script to symlink any hook in git_hooks/ to your local .git/hooks/ folder. Only for personal use to keep my git hooks version controlled.

  • todo
    Never seems to remain empty...

Thanks

The idea for the architecture was taken from Dimitri Merejkowsky's GitHub.