dotfiles/README.md

151 lines
6.3 KiB
Markdown
Raw Normal View History

2016-04-18 11:42:43 +02:00
# dotfiles
These are my dotfiles. They are awesome.
This repo contains my dotfiles which I use at macOS, FreeBSD and Linux systems. This set features a nice and fast zsh config, a neat vim environment and a tmux config.
2016-04-18 11:42:43 +02:00
The workstation realted stuff is mostly tested on macOS. Especially the key bindings may be not portable at the moment.
![Alacritty window using the dotfiles by chrisb86](https://raw.githubusercontent.com/chrisb86/dotfiles/main/screenshot.png)
2016-04-18 11:42:43 +02:00
2021-01-03 22:16:01 +01:00
The zsh prompt is handcrafted to look neat and provide some extra info. When you are root the user- and hostname color changes from blue to red. If you are connected via ssh, the prompt will show some green arrows behind the working path and when you are in a git repository, it will show some git infos at the right side.
2016-04-18 11:42:43 +02:00
The tmux config contains some nice settings to make my work a bit easier and look nice.
2020-07-02 15:30:08 +02:00
My color scheme is the awesome [Nord Color scheme](https://www.nordtheme.com) by Arctic Ice Studio and my font is [~~FiraCode~~](https://github.com/tonsky/FiraCode) [Source Code Pro](https://adobe-fonts.github.io/source-code-pro/).
2016-04-18 11:42:43 +02:00
The repo ships with a Makefile that you can use to deploy and update the dotfiles.
```shell
# make help
help This help
all Update repo, decrypt secrets and run deploy-macos
install Update repor and run deploy-base
deploy-base Only deploy basic conf files for shell usage
deploy-workstation Deploy workstation specific config files (inherits deploy-shell)
deploy-macos Deploy macOS specific config files (inherits deploy-workstation)
gen-vscodium-plugin-list Update the list of VSCodium plugins
git-secrets-hide Hide secrets with git-secret
git-secrets-reveal Reveal secrets with git-secret
git-fetch Fetch changes from origin
git-push Push changes to origin
git-update-submodules Update all submodules
brew-bundle Install applications with brew bundle
brew-bundle-cleanup Removew all appplications that are not listed in Brewfile
deploy-alacritty Deploy alacritty config
deploy-bitbar Deploy BitBar config
deploy-duti Deploy duti config
deploy-espanso Deploy espanso config
deploy-htop Deploy htop config
2021-02-04 09:24:10 +01:00
deploy-htop-zfs Deploy htop config with zfs
deploy-skhd Deploy skhd config
deploy-tmux Deploy tmux config
deploy-vim Deploy vim config
deploy-vscodium Deploy VSCodium config
deploy-yabai Deploy yabai config
deploy-youtubedl Deploy youtube-dl config
deploy-zsh Deploy zsh config
deploy-brewfile Deploy Brewfile
deploy-ssh Deploy SSH config
deploy-hushlogin Deploy .hushlogin
```
The dotfiles will be copied to your **~**.
2016-04-18 11:42:43 +02:00
The repo is initialized for beeing used with git-secret. My own personal secrets are pushed to the repo as well and can be decrypted with my GPG key.
2020-07-04 22:28:28 +02:00
## ZSH with bells and whistles
The ZSH config doesnt use any frameworks and is tuned for speed.
The config delivers some nice extra functions.
### extract()
_extract_ can be run with _extract <filename>_ to extract archives in any given formats.
### tmix()
_tmix_ creates a new tmux session and connects to a given list of servers with mosh and attaches to a tmux session at the server.
You must define a space separated list of servers as _$TMIX_SERVERS=“<SERVERS>”_ e.g. in _~/.zsh/lib/30-extras.zsh_.
You can define a name for the used session in _$TMIX_SESSION=“<SESSION>”_. Otherwise it will use „TMIX“.
_tmix kill_ kills the session.
## tmux config
The tmux config rebinds the prefix key to C-a. It features different shortcuts to make my life easier (e.g. "C-a -„ for splitting the window horizontally.)
It also supports nested sessions with a modified color scheme. Thats nice when using tmix.
![Alacritty window using the dotfiles by chrisb86 in a tmix session](https://raw.githubusercontent.com/chrisb86/dotfiles/main/screenshot-tmix.png)
## Alacritty
I love Alacritty because it's a damn fast Terminal emulator that's configured with a simple text file config.
I've configured it to use tmux for tabs and multiplexing and configured some usefull keybindings.
### Keybindings:
| Key | Modifier(s) | Description |
| -------- | ----------- | ------------------------ |
| N | ⌘ | Spawn a new instance |
| 0 (Zero) | ⌘ | Reset font size |
| + | ⌘ | Increase font size |
| - | ⌘ | Decrease font size |
| J | ⌘ | Move to next session |
| K | ⌘ | Move to previous session |
| T | ⌘ | Create window |
| H | ⌘ | Move to previous window |
| L | ⌘ | Move to next window |
| X | ⌘ | Kill pane/window |
| A | ⌘ | Split pane vertically |
| S | ⌘ | Split pane horizontally |
| Z | ⌘ | Maximize pane |
| T | ⌘⇧ | Create window in nested session |
| H | ⌘⇧ | Move to previous window in nested session |
| L | ⌘⇧ | Move to next window in nested session |
| X | ⌘⇧ | Kill pane/window in nested session |
| A | ⌘⇧ | Split pane vertically in nested session |
| S | ⌘⇧ | Split pane horizontally in nested session |
| Z | ⌘⇧ | Maximize pane in nested session |
| , | ⌘ | Open Alacritty config directory |
| ⌫ | ⌘ | Delete word/line |
| ← | ⌥ | Move one word left |
| → | ⌥ | Move one word right |
| ← | ⌘ | Move to beginning of the line |
| → | ⌘ | Move to end of the line |
2020-07-04 22:28:28 +02:00
2016-04-18 11:42:43 +02:00
## Installation
2016-04-18 11:42:43 +02:00
## ### Getting the dotfiles.
2020-05-02 20:57:54 +02:00
```shell
git clone https://github.com/chrisb86/dotfiles.git
```
2016-04-18 11:42:43 +02:00
### Deploying the dotfiles
2016-04-18 11:42:43 +02:00
For installing the base set for shell usage run
```shell
make install
```
For the fullfl edged setup with decrypting of the secrets use
```shell
make install
```
2016-04-18 11:42:43 +02:00
To list all avaliable commands run:
```shell
make help
```
2016-04-18 11:42:43 +02:00
## Credits
2020-05-02 20:57:54 +02:00
- [Git prompt by Josh Dick](https://gist.github.com/joshdick/4415470)