Easily set up a new computer, restore your packages, applications, configurations, and keep your computer automatically maintained and backed up! Complete with bonus convenience scripts and sensible defaults.
To simplify instructions, the paths provided in this README are for OS X scripts. However, these all have their counterparts for other OSs. You just need to replace the 'osx' part in the paths and, based on the OS, the extension of the script. Sometimes additional minor changes to the path are required as well but it should all be clear and intuitive.
All installations and backups work by providing a profile name for them for easy management of different setups. If you provide no profile name to a script, they'll use the default personal
profile.
Example use:
# Set up your new machine quickly using the default personal profile
install.sh
# Assume you're customising your installation here by installing new packages, editing shell configuration, etc
backup.sh my-work-ci-server
# Now if you're working on your own fork, you can commit this profile and later use it to set up new machines or make reinstallations way easier!
The following steps assume that you are doing the setup on a freshly formatted computer. Therefore you don't even have your SSH keys or anything set up.
Open the Terminal app and enter the commands below.
mkdir ~/Projects
cd ~/Projects
# It's recommended to use your own fork so you can commit your profile changes later on.
git clone https://github.com/isair/dotfiles.git
cd dotfiles
Before typing the following line, make sure you check the files under the profiles/personal
folder and modify them to personalise your setup.
./scripts/osx/install.sh
First, fork this repository and clone it on your machine. Then:
<project-dir>/scripts/osx/backup.sh <profile-name>
This will back-up your packages and apps to the profile you've given, personal
by default. Creating the profile as necessary if it doesn't exist.
The next step is to symlink your configuration files so that any changes to them are picked up by git. Right now there is not fully automated but will be fairly soon.
# Run the lines that apply to your setup
cp ~/.bashrc <project-dir>/profiles/<profile-name>/configurations/bashrc
cp ~/.zshrc <project-dir>/profiles/<profile-name>/configurations/zshrc
cp ~/.vimrc <project-dir>/profiles/<profile-name>/configurations/vimrc
# Then run the following line to symlink these files.
<project-dir>/scripts/unix/symlink-dotfiles.sh <profile-name>
One way to automate backup and cleanup is to add cron jobs for these scripts.
crontab -e
Append the following line, changing the path as necessary.
0 15 * * * ~/projects/dotfiles/scripts/osx/backup.sh
This will update your package list but you'll still need to commit and push yourself, or write a script for it.
sudo crontab -e
Append the following line, changing the path if needed again.
30 9 * * * /home/owner/projects/dotfiles/scripts/osx/cleanup.sh
Your computer will now do a clean-up in the morning, to open up space that you might need during the day. At 15:00, it will do backups.
The back-up scripts support the following package managers.
- brew
- brew cask
- npm
- pip
- apt
- snap
- npm
- pip
- scoop
- bash
- zshell
- hyper.js
- vim
Commit scopes:
- profiles
- scripts
- repo