Skip to content

Instantly share code, notes, and snippets.

@colophonemes
Created August 23, 2021 15:04
Show Gist options
  • Save colophonemes/b9138f2c179408e3781ed5b14639e1dd to your computer and use it in GitHub Desktop.
Save colophonemes/b9138f2c179408e3781ed5b14639e1dd to your computer and use it in GitHub Desktop.
Dotfiles
# Enable Powerlevel10k instant prompt. Should stay close to the top of ~/.zshrc.
# Initialization code that may require console input (password prompts, [y/n]
# confirmations, etc.) must go above this block; everything else may go below.
if [[ -r "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh" ]]; then
source "${XDG_CACHE_HOME:-$HOME/.cache}/p10k-instant-prompt-${(%):-%n}.zsh"
fi
# If you come from bash you might have to change your $PATH.
# export PATH=$HOME/bin:/usr/local/bin:$PATH
# Path to your oh-my-zsh installation.
export ZSH="/Users/sam/.oh-my-zsh"
# Set name of the theme to load --- if set to "random", it will
# load a random theme each time oh-my-zsh is loaded, in which case,
# to know which specific one was loaded, run: echo $RANDOM_THEME
# See https://github.com/ohmyzsh/ohmyzsh/wiki/Themes
ZSH_THEME="powerlevel10k/powerlevel10k"
# per https://gist.github.com/kevin-smets/8568070
POWERLEVEL9K_MODE="awesome-patched"
# Set list of themes to pick from when loading at random
# Setting this variable when ZSH_THEME=random will cause zsh to load
# a theme from this variable instead of looking in ~/.oh-my-zsh/themes/
# If set to an empty array, this variable will have no effect.
# ZSH_THEME_RANDOM_CANDIDATES=( "robbyrussell" "agnoster" )
# Uncomment the following line to use case-sensitive completion.
# CASE_SENSITIVE="true"
# Uncomment the following line to use hyphen-insensitive completion.
# Case-sensitive completion must be off. _ and - will be interchangeable.
# HYPHEN_INSENSITIVE="true"
# Uncomment the following line to disable bi-weekly auto-update checks.
# DISABLE_AUTO_UPDATE="true"
# Uncomment the following line to automatically update without prompting.
# DISABLE_UPDATE_PROMPT="true"
# Uncomment the following line to change how often to auto-update (in days).
# export UPDATE_ZSH_DAYS=13
# Uncomment the following line if pasting URLs and other text is messed up.
# DISABLE_MAGIC_FUNCTIONS=true
# Uncomment the following line to disable colors in ls.
# DISABLE_LS_COLORS="true"
# Uncomment the following line to disable auto-setting terminal title.
# DISABLE_AUTO_TITLE="true"
# Uncomment the following line to enable command auto-correction.
# ENABLE_CORRECTION="true"
# Uncomment the following line to display red dots whilst waiting for completion.
# COMPLETION_WAITING_DOTS="true"
# Uncomment the following line if you want to disable marking untracked files
# under VCS as dirty. This makes repository status check for large repositories
# much, much faster.
# DISABLE_UNTRACKED_FILES_DIRTY="true"
# Uncomment the following line if you want to change the command execution time
# stamp shown in the history command output.
# You can set one of the optional three formats:
# "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd"
# or set a custom format using the strftime function format specifications,
# see 'man strftime' for details.
# HIST_STAMPS="mm/dd/yyyy"
# Would you like to use another custom folder than $ZSH/custom?
# ZSH_CUSTOM=/path/to/new-custom-folder
# Tell the zsh-nvm plugin to auto-load from .nvmrc on entering a directory
export NVM_AUTO_USE=true
# Which plugins would you like to load?
# Standard plugins can be found in ~/.oh-my-zsh/plugins/*
# Custom plugins may be added to ~/.oh-my-zsh/custom/plugins/
# Example format: plugins=(rails git textmate ruby lighthouse)
# Add wisely, as too many plugins slow down shell startup.
plugins=(git nvm vscode zsh-nvm yarn-autocompletions)
source $ZSH/oh-my-zsh.sh
# User configuration
# Don't share history between terminal sessions
# https://stackoverflow.com/a/48880229/7114675
setopt noincappendhistory
setopt nosharehistory
setopt appendhistory
# Source version managers
## rbenv / Ruby
eval "$(rbenv init - zsh)"
## pyenv / Python
eval "$(pyenv init -)"
eval "$(pyenv virtualenv-init -)"
## Other completions - comes after rbenv so that tmuxinator completions get picked up
fpath=(~/.zsh $fpath)
# export MANPATH="/usr/local/man:$MANPATH"
# You may need to manually set your language environment
# export LANG=en_US.UTF-8
# Preferred editor for local and remote sessions
if [[ -n $SSH_CONNECTION ]]; then
export EDITOR='vim'
else
export EDITOR='code'
fi
# Tell `less` not to clear the screen on exit
export LESS="-XFR"
# Compilation flags
# export ARCHFLAGS="-arch x86_64"
# Set personal aliases, overriding those provided by oh-my-zsh libs,
# plugins, and themes. Aliases can be placed here, though oh-my-zsh
# users are encouraged to define aliases within the ZSH_CUSTOM folder.
# For a full list of active aliases, run `alias`.
#
# Example aliases
# alias zshconfig="mate ~/.zshrc"
# alias ohmyzsh="mate ~/.oh-my-zsh"
prompt_context(){}
# To customize prompt, run `p10k configure` or edit ~/.p10k.zsh.
[[ ! -f ~/.p10k.zsh ]] || source ~/.p10k.zsh
# Syntax highlighting
source /usr/local/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh
#alias tmuxinator to mux
alias mux=tmuxinator
# utilities
alias flushDNS='sudo dscacheutil -flushcache; sudo killall -HUP mDNSResponder'
# HSTR configuration - add this to ~/.zshrc
alias hh=hstr # hh to be alias for hstr
setopt histignorespace # skip cmds w/ leading space from history
export HSTR_CONFIG=hicolor # get more colors
bindkey -s "\C-r" "\C-a hstr -- \C-j" # bind hstr to Ctrl-r (for Vi mode check doc)
# The next line updates PATH for the Google Cloud SDK.
if [ -f '/usr/local/bin/gcloud/path.zsh.inc' ]; then . '/usr/local/bin/gcloud/path.zsh.inc'; fi
# The next line enables shell command completion for gcloud.
if [ -f '/usr/local/bin/gcloud/completion.zsh.inc' ]; then . '/usr/local/bin/gcloud/completion.zsh.inc'; fi
# short command to create a PR
pr () {
hub pull-request -b dev -o -m $1
}
# Short command to create a PR with the most recent commit message as the title
prm () {
hub pull-request -b dev -o -m "$(git log -1 --pretty=%s)"
}
mongo-ea-prod-url () {
node -p -e "JSON.stringify(require('./config-prod.secret'));" | jq -r '.app.env.MONGO_URL'
}
mongo-ea-prod () {
mongo $@ $(mongo-ea-prod-url)
}
password () {
chars=${1:-32}
inputlen="$((chars * 2))"
openssl rand -base64 $inputlen | tr -dc A-Za-z0-9 | head -c$chars && echo ""
}
# ZOxide https://github.com/ajeetdsouza/zoxide
eval "$(zoxide init zsh)"
[ -f ~/.fzf.zsh ] && source ~/.fzf.zsh
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment