• Stars
    star
    221
  • Rank 179,773 (Top 4 %)
  • Language
    Emacs Lisp
  • License
    GNU General Publi...
  • Created over 4 years ago
  • Updated 5 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

My dotfiles for Bash/Zsh, Vim/Neovim, Doom Emacs, tmux, Git, terminal emulators, JupyterLab, aria2, mpv, Nix and Homebrew

Dotfiles

Latest commit

My dotfiles. Some of my considerations are explained in Wiki.

Deployment โ€ข Shell โ€ข Vim/Neovim โ€ข Doom Emacs โ€ข tmux โ€ข Git โ€ข Terminal emulators โ€ข Other config

More screenshots here.

Features

Deploy with ease and efficiency

chezmoi is used to bootstrap dotfiles.

  • Deploy with shell one-liner:

    sh -c "$(curl -fsLS git.io/chezmoi)" -- init --apply g6ai
  • Uses text/template syntax from Go extended with text template functions from sprig.

    For instance, here is a typical snippet in one of my dotfiles, init.vim.tmpl, residing in private_dot_config/nvim:

    {{ $x := splitList "_" .chezmoi.sourceFile /* private dot config/nvim/init.vim.tmpl */ -}}
    {{ $y := last $x | dir /* config/nvim */ -}}
    {{ $rtp := list "~/." $y | join "" /* ~/.config/nvim */ -}}
    {{ $vim_flag := .vim_flag -}}
    {{ template "vim/vimrc" dict "rtp" $rtp "os" .chezmoi.os "vim_flag" $vim_flag -}}

    It passes variables rtp, os and vim_flag to a common vimrc template in .chezmoitemplates/vim. This vimrc template contains both the actual config details and the logic operations which check the variables it receives on deployment, so it can generate different config per Vim variants (Vim or Neovim), OS (Linux or macOS) and other user-defined variables.

    Such snippets are extensively used in these dotfiles to manage config files of different environments in one place (.chezmoitemplates), keeping the resource-demanding logical operations at the deployment step rather than the runtime.

Shell

Vim/Neovim

  • The configs are located in the .chezmoitemplates/vim directory. They are then deployed to Vim and Neovim's runtime path.
    • Vim's vimrc.tmpl template and Neovim's init.vim.tmpl template use the versatile configs in vimrc template, which works for Linux, macOS and Windows! You can set if your system is good enough to enable plugins on chezmoi deployment.
    • Most of the vimrc's functionalities are divided and located in core directory.
  • Neovim-specific config:
    • Adopts the mighty coc.nvim. Its config is coc-settings.json.
    • Some experimetal features in Neovim 0.5+ are also embraced:

Doom Emacs

tmux

  • tmux.conf defines tmux's style and key bindings, etc. Access to system clipboard is supported:
    • For macOS, pbcopy is used. pbcopy is installed on macOS by default.
    • For Linux, xclip is used. xclip needs to be installed. Within an SSH session, primary and/or clipboard content on the remote server can be sent to local machine by X11 forwarding.
  • Helper scripts executable_update_display_vim.sh and executable_update_vim.sh update environment variable $DISPLAY and/or Vim/Neovim theme.

Git

Global dot_gitignore_global.tmpl per OS template. GitHubโ€™s collection of .gitignore file templates are used.

Terminal emulators

From my experience, there's no perfect terminal emulator. I have tried Terminal.app, iTerm2, Alacritty, kitty and WezTerm. Currently I'm using WezTerm.

  • wezterm folder includes the WezTerm configuration file wezterm.lua.
  • kitty folder includes the kitty configuration file kitty.conf for different OS.
  • alacritty folder includes the Alacritty configuration file alacritty.yml for different OS.

Other config