Skip to content

mvilrokx/dotfiles

Repository files navigation

Mark’s dotfiles

This is cloned/copied from https://github.com/mathiasbynens/dotfiles but has been adapted for my needs, you should do the same!

Installation

Warning: If you want to give these dotfiles a try, you should first fork this repository, review the code, and remove things you don’t want or need. Don’t blindly use my settings unless you know what that entails. Use at your own risk!

Using Git and the bootstrap script

You can clone the repository wherever you want. (I like to keep it in ~/Projects/dotfiles, with ~/dotfiles as a symlink.) The bootstrapper script will pull in the latest version and copy the files to your home folder.

git clone https://github.com/mvilrokx/dotfiles.git && cd dotfiles && source bootstrap.sh

To update, cd into your local dotfiles repository and then:

source bootstrap.sh

Alternatively, to update while avoiding the confirmation prompt:

set -- -f; source bootstrap.sh

Git-free install

To install these dotfiles without Git:

cd; curl -#L https://github.com/mvilrokx/dotfiles/tarball/main | tar -xzv --strip-components 1 --exclude={README.md,bootstrap.sh,.osx,LICENSE-MIT.txt}

To update later on, just run that command again.

Specify the $PATH

If ~/.path exists, it will be sourced along with the other files, before any feature testing (such as detecting which version of ls is being used) takes place.

Here’s an example ~/.path file that adds /usr/local/bin to the $PATH:

export PATH="/usr/local/bin:$PATH"

Add custom commands without creating a new fork

If ~/.extra exists, it will be sourced along with the other files. You can use this to add a few custom commands without the need to fork this entire repository, or to add commands you don’t want to commit to a public repository.

My ~/.extra looks something like this:

# Git credentials
# Not in the repository, to prevent people from accidentally committing under my name
GIT_AUTHOR_NAME="Mark Vilrokx"
GIT_COMMITTER_NAME="$GIT_AUTHOR_NAME"
git config --global user.name "$GIT_AUTHOR_NAME"
GIT_AUTHOR_EMAIL="mvirokx@gmail.com"
GIT_COMMITTER_EMAIL="$GIT_AUTHOR_EMAIL"
git config --global user.email "$GIT_AUTHOR_EMAIL"

You could also use ~/.extra to override settings, functions and aliases from my dotfiles repository. It’s probably better to fork this repository instead, though.

Post Install steps (optional)

Sensible macOS defaults

When setting up a new Mac, you may want to set some sensible macOS defaults:

./.macos

Install Homebrew formulae

When setting up a new Mac, you may want to install some common Homebrew formulae (after installing Homebrew, of course):

./brew.sh

Some of the functionality of these dotfiles depends on formulae installed by brew.sh. If you don’t plan to run brew.sh, you should look carefully through the script and manually install any particularly important ones. A good example is Bash/Git completion: the dotfiles use a special version from Homebrew.

Install oh-my-zsh

I use the ZSH shell on my Mac with oh-my-zsh. You can use the included oh-my-zsh.sh script to install it with some plugins I like to use:

./oh-my-zsh.sh

Customize Apps in Dock

I use this to remove all apps from the dock and add the ones I want/use:

./dock.sh

Manual Steps

I have to do these steps manually, in the UI, because I cannot find a way to do this from the CLI:

  1. Set the Bluetooth Icon in the menubar
  2. Set the Mouse Speed (in BetterTouchTool or System Preferences)
  3. Install Golang. There is a brew pkg available, but I think it is recommended that you just donwload and install it as per the instructions on the go.dev website.
  4. Add License Keys for:
    1. Alfred
    2. BetterTouchTool
    3. Typora
  5. Add Folders to Favorites
  6. Add "Internet Accounts" (System Preferences). Start with iCloud as I believe that pulls in all the other ones.

For work laptop:

  1. Setup VPNs

Feedback

Suggestions/improvements welcome!

Author

twitter/mvilrokx
Mark Vilrokx

Thanks to…

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages