Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eliasnorrby/dotfiles
:computer: Dotfiles for development on MacOS and Manjaro
https://github.com/eliasnorrby/dotfiles
alacritty ansible arch-linux bspwm dotfiles dotfiles-macos dotfiles-manager emacs hammerspoon karabiner sxhkd tmux vim zsh
Last synced: 3 months ago
JSON representation
:computer: Dotfiles for development on MacOS and Manjaro
- Host: GitHub
- URL: https://github.com/eliasnorrby/dotfiles
- Owner: eliasnorrby
- License: mit
- Created: 2018-11-09T09:16:42.000Z (about 6 years ago)
- Default Branch: develop
- Last Pushed: 2024-09-16T18:44:59.000Z (4 months ago)
- Last Synced: 2024-09-16T23:38:46.131Z (4 months ago)
- Topics: alacritty, ansible, arch-linux, bspwm, dotfiles, dotfiles-macos, dotfiles-manager, emacs, hammerspoon, karabiner, sxhkd, tmux, vim, zsh
- Language: Shell
- Homepage:
- Size: 2.04 MB
- Stars: 8
- Watchers: 2
- Forks: 1
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# .DOTFILES
[![github-actions][github-actions-badge]][github-actions-link]
[![semantic-release][semantic-release-badge]][semantic-release-link]
[![Conventional Commits][conventional-commits-badge]][conventional-commits-link]Declarative dotfiles for development on MacOS and Manjaro.
## Bootstrap
To provision a new workstation from scratch, use the `setup.sh` (or `setup-linux.sh`) script.
Run
```bash
bash <(curl -sL https://raw.githubusercontent.com/eliasnorrby/dotfiles/develop/setup.sh)
```Prepare to input your password a couple of times.
This setup script will:
- Install homebrew
- Install `python3` and `openssl` (using `brew`)
- Download a snapshot version of this repo
- Install `ansible` (using `brew`)
- Install `ansible` role dependencies
- Run the downloaded playbook (`_provision/playbook.yml`), wherein:
- This repo is cloned to `~/.dotfiles`
- Symlinks are created
- xcode command line tools are installed (or verified to have been installed)
- Dependencies are downloaded (using `homebrew`, `pip`, `ruby` and `npm`)
- Run the post-install script, wherein:- `zsh` plugins are installed
- `vim` plugins are installed
- `coc-nvim` extensions are installed
- `vscode` plugins are installed
- `doom-emacs` packages are installed:clock1: Estimated duration: ~45 minutes
Dependencies:
- [geerlingguy/homebrew][geerlingguy-homebrew-link]
- [geerlingguy/git][geerlingguy-git-link]
- [kewlfft/aur][kewlfft-aur-link]## Directory structure
Configuration is divided into `topics` (inspired by
[hlissner][hlissner-dotfiles-link]).Example topics:
- `shell/zsh`
- `shell/tmux`
- `editor/vim`Topics are grouped by category (`editor`, `shell`, etc). Each topic must contain
a `topic.config.yml`, and can optionally include a `topic.tasks.yml`, an
`aliases.zsh`, an `env.zsh`, as well as any other files relevant to its
configuration.Ansible tasks defined in `topic.tasks.yml` will be run during provisioning.
Environment variables defined in `env.zsh` will be sourced during shell startup
if the topic is enabled. The same is true for aliases defined in `aliases.zsh`.```
.dotfiles
└── group
├── topic
│ ├── aliases.zsh
│ ├── env.zsh
│ ├── topic.config.yml
│ └── topic.tasks.yml
└── another-topic
```_Minimal example of a topic directory layout_
Extended directory layout example
```
.dotfiles
├── editor
│ ├── editorconfig
│ │ └── topic.config.yml
│ ├── emacs
│ │ ├── aliases.zsh
│ │ ├── topic.config.yml
│ │ ├── doom
│ │ │ ├── config.el
│ │ │ ├── init.el
│ │ │ └── packages.el
│ │ └── env.zsh
│ └── vim
│ ├── aliases.zsh
│ ├── env.zsh
│ ├── gvimrc.vim
│ └── topic.config.yml
└── shell
├── alacritty
│ ├── alacritty.yml
│ ├── aliases.zsh
│ └── topic.config.yml
├── git
│ ├── aliases.zsh
│ └── topic.config.yml
├── tmux
│ ├── aliases.zsh
│ ├── env.zsh
│ ├── scripts
│ │ └── uptime-tmux-status.sh
│ ├── tmux-cheatsheet.md
│ ├── tmux.conf
│ ├── tmux.remote.conf
│ ├── tmux.theme.conf
│ └── topic.config.yml
└── zsh
├── aliases.zsh
├── completion.zsh
├── config.zsh
├── fzf.zsh
├── keybinds.zsh
├── macos.zsh
├── plugins.zsh
├── prompt.zsh
├── remote.zsh
├── utilities.zsh
├── topic.config.yml
└── topic.tasks.yml
```Each topic declares its configuration (brew dependencies, symlinks, etc) in a
`topic.config.yml` within its coresponding directory.```yaml
vim_config:
path: editor/vim
links:
- .vimrc
brew_formulas:
- vim
```_Topic configuration example_
Possible fields in `topic.config.yml`:
- `path` (required)
- `links`
- `become`
- `brew_formulas`
- `brew_casks`
- `brew_taps`
- `pacman_packages`
- `aur_packages`
- `osx_defaults`
- `npm_packages`
- `pip_packages`
- `gem_packages`
- `mas_apps`:bangbang: **TODO**: Describe topic config api in detail.
Each topic configuration is mapped to `root.config.yml`:
```yaml
topics:
editor:
- name: vim
state: present
config: "{{ vim_config }}"
- name: emacs
state: present
config: "{{ emacs_config }}"
- name: editorconfig
state: disabled
config: "{{ editorconfig_config }}"
keyboard:
- name: hammerspoon
state: present
config: "{{ hammerspoon_config }}"
- name: karabiner
state: present
config: "{{ karabiner_config }}"
shell:
- name: tmux
state: present
config: "{{ tmux_config }}"
- name: zsh
state: present
config: "{{ zsh_config }}"
lang:
- name: java
state: present
config: "{{ java_config }}"
- name: go
state: absent
config: "{{ go_config }}"
```_Root dotfile configuration example_
In `root.config.yml`, topics can be enabled/disabled/removed by setting
their `state` to one of `present`, `disabled` or `absent`. Upon running,- `present` topics will have their symlinks created (if they don't exist
already) and their dependencies installed
- `disabled` topics will have their symlinks removed (if they exist), but their
dependencies left alone (if they are installed)
- `absent` topics will have their symlinks removed (if they exist) and their
dependencies uninstalled (if they are installed)## CLI
> :wrench: [eliasnorrby/dotfiles-cli][dotfiles-cli-link]
The CLI provides a simpler way to edit, view and apply configurations.
## Leftovers
After running the provisioning script, there are a few things that need to be
configured manually.### General
- Set the computer name
- (MacOS) Preferences → Sharing
- (Linux) `sudo scutil --set HostName `
- Generate ssh keys
```bash
ssh-keygen -t ed25519 -C "[email protected]"
gh auth login
```
- Docs: [Generate][ssh-github-generate], [Add][ssh-github-add]### MacOS
- Start all apps and prepare to grant lots of privileges
- Start with Karabiner and Hammerspoon to enable app shortcuts
- Set main Alfred hotkey to ⌥ + SPACE
- Set desktop background (assets available in Dropbox)
- Add additional desktops
- Enable shortcuts for desktop navigation (Preferences → Keyboard → Shortcuts → Mission Control)
- Remap layout switching shortcuts (Preferences → Keyboard → Shortcuts → Input Sources)
- Add Amethyst padding (`2 px` window margin, `5 px` screen padding)
- Start Amethyst on Login (menubar configuration)
- Configure Bartender to hide the appropriate icons, supply license
- Import iStatMenus settings from `assets/istatmenus`, supply license
- Some apps may require Rosetta to run
- `/usr/sbin/softwareupdate --install-rosetta --agree-to-license`
- Add Workman-P layout (?)### Optional
- Download the [Dank Mono font](https://dank.sh)
## Troubleshooting
### zsh: compinit complains about insecure directories
It's probably mentioning `/usr/local/share/zsh`. Resolve it by running e.g:
```bash
sudo chown -R eliasnorrby:admin /usr/local/share/zsh
sudo chmod -R 755 /usr/local/share/zsh
```[github-actions-badge]: https://github.com/eliasnorrby/dotfiles/actions/workflows/ci.yml/badge.svg
[github-actions-link]: https://github.com/eliasnorrby/dotfiles/actions/workflows/ci.yml
[semantic-release-badge]: https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg
[semantic-release-link]: https://github.com/semantic-release/semantic-release
[conventional-commits-badge]: https://img.shields.io/badge/Conventional%20Commits-1.0.0-yellow.svg
[conventional-commits-link]: https://conventionalcommits.org
[geerlingguy-homebrew-link]: https://homebrewhub.com/geerlingguy/ansible-role-homebrew
[geerlingguy-git-link]: https://github.com/geerlingguy/ansible-role-git
[kewlfft-aur-link]: https://github.com/kewlfft/ansible-aur
[hlissner-dotfiles-link]: https://github.com/hlissner/dotfiles
[dotfiles-cli-link]: https://github.com/eliasnorrby/dotfiles-cli
[ssh-github-generate]: https://docs.github.com/en/free-pro-team@latest/github/authenticating-to-github/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent
[ssh-github-add]: https://docs.github.com/en/free-pro-team@latest/github/authenticating-to-github/adding-a-new-ssh-key-to-your-github-account