Skip to content
🔧 .files, including ~/.osx — sensible hacker defaults for OS X
Branch: master
Clone or download
Pull request Compare This branch is 159 commits ahead, 118 commits behind mathiasbynens:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
.fontconfig
.vim
.zsh
bash-scripts
bin
init
.aliases
.bash_aliases
.bash_profile
.bash_prompt
.bashrc
.curlrc
.editorconfig
.exports
.functions
.gdbinit
.gitattributes
.gitconfig
.gitignore
.gitignore_global
.gitk
.gitmodules
.gvimrc
.hgignore
.hgignore_global
.hushlogin
.inputrc
.jsbeautifyrc
.npmrc
.osx
.screenrc
.tmux.conf
.viminfo
.vimrc
.wgetrc
.zshrc
LICENSE-MIT.txt
README.md
bootstrap.sh
brew.sh
dotfiles.sublime-project
non-brew.sh
zshrc.sh

README.md

CJ’s dotfiles

Screenshot of my shell prompt

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 ~/code/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/whoaa512/dotfiles.git && cd dotfiles && bash bootstrap.sh

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

bash 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/whoaa512/dotfiles/tarball/master | tar -xzv --strip-components 1 --exclude={README.md,bootstrap.sh,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="C.J. Winslow"
GIT_COMMITTER_NAME="$GIT_AUTHOR_NAME"
git config --global user.name "$GIT_AUTHOR_NAME"
GIT_AUTHOR_EMAIL="cj@mailinator.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.

Sensible OS X defaults

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

./.osx

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

General Order

In general I do the following on a new laptop:

# Install brew
ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
# Install oh-my-zsh
sh -c "$(curl -fsSL https://raw.github.com/robbyrussell/oh-my-zsh/master/tools/install.sh)"
# Clone repo & bootstrap
cd ~ && mkdir code && cd code; git clone https://github.com/whoaa512/dotfiles.git && cd dotfiles && bash bootstrap.sh
# Run the brew formulae
bash brew.sh
# Run the non-brew stuff, mainly Node.js
bash non-brew.sh
# OS X Defaults
~/code/dotfiles/.osx

Feedback

Suggestions/improvements welcome!

Author

twitter/mathias
Mathias Bynens

Thanks to…

You can’t perform that action at this time.