This is kind of a reference/handbook/guide for me to use while setting up a new Macbook. Maybe in the distant future this'll be worth automating, but I'm really not setting up Apple computers often enough for this to become especially burdensome. Plus, I think it's kind of good to actually go through the steps manually each time as a final defense against anything out of the ordinary. Happy ricing!
Install Xcode Command Line Tools.
xcode-select --install
Globally set Git configuration values.
git config --global user.name "First Last"
git config --global user.email [email protected]
Generate an SSH key. Save the key in the default file with no passphrase.
ssh-keygen -t ed25519 -C "[email protected]"
Start the ssh-agent in the background.
eval "$(ssh-agent -s)"
Add the key to the ssh-agent.
ssh-add ~/.ssh/id_ed25519
Make sure to add the public key to your GitHub account's public keys! Copy the key from the file it was saved to.
pbcopy < ~/.ssh/id_ed25519.pub
Install Homebrew.
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
Add Homebrew to your PATH.
(echo; echo 'eval "$(/opt/homebrew/bin/brew shellenv)"') >> ~/.zprofile
eval "$(/opt/homebrew/bin/brew shellenv)"
Clone this repository. CD into it.
git clone --recurse-submodules [email protected]:bashar-515/dotfiles.git
cd dotfiles
Install the desired Homebrew packages, and then return to HOME.
brew bundle
Install pyenv-pyright
git clone https://github.com/alefpereira/pyenv-pyright.git $(pyenv root)/plugins/pyenv-pyright
cd ~
Remove the .zprofile file created when adding Homebrew to PATH from your home directory.
rm .zprofile
Move the .ssh directory and .gitconfig file into the dotfiles repository.
mv .gitconfig dotfiles/git/.gitconfig
mv .ssh dotfiles/ssh/
Now, it's finally time to stow our configuration and dot files! CD back into this directory and stow away.
cd dotfiles
stow alacritty
stow bash
stow git
stow ssh
stow zsh
stow tmux
stow starship
stow fastfetch
stow nvim
stow aliases
stow wezterm
stow viam
stow aerospace
That concludes the initalization from within the Mac Terminal. The next steps are more fun to do in Alacritty!
Everything should be ready on launch. With Tmux, you might have to press "Shift+i" after pressing the leader from within a Tmux session. You might also have to potentially source the Tmux configuration file afterwards by entering "r" after pressing the leader.
For Sublime, enter the app and open the command palette (CMD+Shift-p). Select "Install Package Control" to be able to install packages (themes, plugins, etc.).
Some desired settings can be set by simply running the the .macos script in this repository after giving it the right permissions.
chmod u+x .macos
./.macos
The settings that follow must be changed manually through a GUI (like the computers system settings).
- Navigate desktops using CTRL+DesktopNumber: System Settings -> Keyboard -> Keyboard Shortcuts -> Mission Control -> "check" the Mission Control option
- Stop automatically rearranging desktops: System Settings -> Desktop & Dock -> turn off "Automatically rearrange Spaces based on most recent use"
- Turn dock hiding off: System Settings -> Keyboard -> Keyboard Shortcuts -> Launchpad & Dock -> uncheck "Turn Dock hiding on/off"
Once step 3 is completed, Rectangle's settings can be imported from RectangleConfig.json.
- Swap control and Caps Lock keys: System Settings -> Keybaord -> Keyboard Shortcuts -> Modifier Keys -> Swap Control and Caps Lock from their respective dropdown menus
- Install Sublime's package manager: open command palette from within Sublime (cmd+shift+p) -> type "Install Package Control" -> hit enter
- Install and set Sublime colorscheme to Dracula
- (Finder) show path bar: from "view" in top bar of screen, select "show path bar"
- (Finder) show status bar: from "view" in top bar of screen, select "show status bar"
- Prevent screen from dimming on batter: System Settings -> battery -> options -> turn off "Slightly dim the display on battery"
- Stop automatically adjusting brightness: System Settings -> Displays -> turn off "automatically adjust brightness"
- Turn off keyboard backlighting: System Settings -> Keyboards -> turn keyboard brightness all the way down and turn off "Adjust keyboard brightness in low light"
- Automatically show and hide the dock: System Settings -> Desktop & Dock -> Turn on "Automatically show and hide the dock"
- Make dock smaller: System Settings -> Desktop & Dock -> decrease "size" slider
- Show scroll bar: System Settings -> Appearance -> check "Always" under "Show scroll bars"
- Click scroll bar: System Settings -> Appearance -> check "Jump to spot that's clicked" under "Click in the scroll bar to"
- Don't play sound on startup: System Settings -> sound -> turn off "Play sound on startup"
- Stop rearranging apps in dock: System Settings -> Desktop and Dock -> turn off "show suggested and recent apps in dock"
- Set firefox as default browser
- Lock screen: Start screen saver when inactive (for 20 min), turn display off on battery when inactive for 30 min, turn display off on power adapter when inactive for 1 hour, require password after screen saver begins or display is turned off immediately
- Don't autofill passwords: System Settings -> Passwords -> password options -> turn off autofill passwords and passkeys
Note: Every shell uses zsh (i.e., it's the default shell, and it's used in wezterm, tmux on wezterm, and tmux on alacritty). Pure alacritty, though, uses bash.
WORK installs download 1-3 through brew on non-work computer
- Slack (jamf)
- Zoom (jamf)
- 1password (jamf)
HOME installs
- Slack (Brew)
- Zoom (Brew)
- 1password (Brew)
- Numbers (App store)
- Google Chrome (Brew)
BOTH installs
- delve (go install)
- Logi Options+ (online)
- flutter (manually from online), extract to ~/Developer folder
Python workflow
pyenv install 3.12 # installs python version
pyenv virtualenv project # creates virtual environment
pyenv local project # sets local python version (i.e., within cwd) to be virtual environment
pyenv pyright # points pyright lsp to use local environment
TODO
- have WezTerm use zsh and Alacritty use Bash regardless of tmux
- figure out why virtual env name shows up above prompt in zsh
- fix starship space between cwd and git branch bug
- nvim "go to declaration" not working
- configure bash completions