From 9ed111d2c94c43e7270baa6221c5046a8b48311a Mon Sep 17 00:00:00 2001 From: Tommy Harris Date: Mon, 14 Dec 2020 23:11:23 -0700 Subject: [PATCH] initial commit --- .zshrc | 178 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ README.md | 1 + 2 files changed, 179 insertions(+) create mode 100644 .zshrc create mode 100644 README.md diff --git a/.zshrc b/.zshrc new file mode 100644 index 0000000..34f58f2 --- /dev/null +++ b/.zshrc @@ -0,0 +1,178 @@ +# 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="$HOME/.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="agnoster" + +# 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 $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 + +# Which plugins would you like to load? +# Standard plugins can be found in $ZSH/plugins/ +# Custom plugins may be added to $ZSH_CUSTOM/plugins/ +# Example format: plugins=(rails git textmate ruby lighthouse) +# Add wisely, as too many plugins slow down shell startup. +plugins=(git) + +source $ZSH/oh-my-zsh.sh + +# User configuration + +# 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='mvim' +# fi + +# 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" + +### SSH Agent Connect ### +function sshagent_findsockets { + find /tmp -uid $(id -u) -type s -name agent.\* 2>/dev/null +} + +function sshagent_testsocket { + if [ ! -x "$(which ssh-add)" ] ; then + echo "ssh-add is not available; agent testing aborted" + return 1 + fi + + if [ X"$1" != X ] ; then + export SSH_AUTH_SOCK=$1 + fi + + if [ X"$SSH_AUTH_SOCK" = X ] ; then + return 2 + fi + + if [ -S $SSH_AUTH_SOCK ] ; then + ssh-add -l > /dev/null + if [ $? = 2 ] ; then + echo "Socket $SSH_AUTH_SOCK is dead! Deleting!" + rm -f $SSH_AUTH_SOCK + return 4 + else + echo "Found ssh-agent $SSH_AUTH_SOCK" + return 0 + fi + else + echo "$SSH_AUTH_SOCK is not a socket!" + return 3 + fi +} + +function sshagent_init { + # ssh agent sockets can be attached to a ssh daemon process or an + # ssh-agent process. + + AGENTFOUND=0 + + # Attempt to find and use the ssh-agent in the current environment + if sshagent_testsocket ; then AGENTFOUND=1 ; fi + + # If there is no agent in the environment, search /tmp for + # possible agents to reuse before starting a fresh ssh-agent + # process. + if [ $AGENTFOUND = 0 ] ; then + for agentsocket in $(sshagent_findsockets) ; do + if [ $AGENTFOUND != 0 ] ; then break ; fi + if sshagent_testsocket $agentsocket ; then AGENTFOUND=1 ; fi + done + fi + + # If at this point we still haven't located an agent, it's time to + # start a new one + if [ $AGENTFOUND = 0 ] ; then + eval `ssh-agent` + fi + + # Clean up + unset AGENTFOUND + unset agentsocket + + # Finally, show what keys are currently in the agent + ssh-add -l +} + +alias sagent="sshagent_init" + +# load aliases from .config +source $HOME/.config/aliasrc 2>/dev/null + +# define 'less'; only use pagination if output exceeds terminal +export LESS="-F -X $LESS" + +# Load zsh-syntax-highlighting; should be last +source /usr/share/zsh/plugins/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh 2>/dev/null diff --git a/README.md b/README.md new file mode 100644 index 0000000..96bf7ed --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +# dotfiles