/dotfiles

Primary LanguageVim ScriptMIT LicenseMIT

My Dotfiles for macOS

dotfiles screenshot

These are the dotfiles I use on my Macs, currently running macOS Mojave (10.14). They are geared primarily towards Ruby/Rails and Node.js web development using Zsh (via Oh-My-Zsh), Vim/Neovim, and Tmux. Also included are my iTerm2 and Terminal.app profiles.

Mac Bootstrap Script

This repo previously contained my entire provisioning solution for a new machine running a fresh install of macOS. I've now extracted the provisioning functionality into its own repository. Check it out:

Provision a new Mac with Mac Bootstrap.

NOTE: Mac Bootstrap automatically clones and installs this dotfiles repo.

Prerequisites

The dotfiles assume you are running macOS with the following software pre-installed:

All of the above and more are included in Mac Bootstrap

Installation

git clone https://github.com/joshukraine/dotfiles.git ~/dotfiles
. ~/dotfiles/install.sh

Post-install Tasks

After running install.sh there are still a couple of things that need to be done.

  • Set up iTerm2 or Terminal.app profile (see details below).
  • Add personal data to ~/.gitconfig.local, ~/.vimrc.local, and ~/.zshrc.local.
  • Complete Brew Bundle with brew bundle install
  • After opening Neovim, run :checkhealth and resolve errors/warnings.

Setting up iTerm2

Thanks to a great blog post by Trevor Brown, I learned that you can quickly set up iTerm2 by exporting your profile. Here are the steps.

  1. Open iTerm2.
  2. Select iTerm2 > Preferences.
  3. Under the General tab, check the box labeled "Load preferences from a custom folder or URL:"
  4. Press "Browse" and point it to ~/dotfiles/iterm2/com.googlecode.iterm2.plist.
  5. Restart iTerm2.

Setting up Terminal.app

Getting set up after a fresh install is simple.

  1. Open Terminal.app.
  2. Select Terminal > Preferences. (But really you'll just press ⌘, right? So much faster.)
  3. Select the Profiles tab.
  4. Click the gear icon and select Import...
  5. Select ~/dotfiles/terminal/<desired-profile>.terminal and click Open.
  6. Click the Default button to keep using this profile in new Terminal windows.

A Note about Vim performance and Ruby files

I recently discovered a resolution to some significant performance issues I had been experiencing running Vim on macOS. These issues were particularly painful when editing Ruby files. I've documented what I learned here:

What I've learned about slow performance in Vim

Vim vs. Neovim

I'm currently trying out Neovim, and so far things are working nicely. For now I have things set up so I can run either Vim or Neovim interchangeably. This is accomplished by telling Neovim's config file (~/.config/nvim/init.vim) to source the standard Vim config file (~/.vimrc).

More info:

Some of my favorite dotfile repos

Helpful web resources on dotfiles, et al.

License

Copyright © 2018 Joshua Steele. MIT License