๐Ÿ“ฆ derek-adair / dotfiles

๐Ÿ“„ .zshrc ยท 205 lines
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205# Path to your oh-my-zsh installation.
export ZSH=$HOME/.oh-my-zsh

# Set name of the theme to load.
# Look in ~/.oh-my-zsh/themes/
# Optionally, if you set this to "random", it'll load a random theme each
# time that oh-my-zsh is loaded.
ZSH_THEME="dracula"

# Uncomment the following line to use case-sensitive completion.
# CASE_SENSITIVE="true"

# Uncomment the following line to disable bi-weekly auto-update checks.
# DISABLE_AUTO_UPDATE="true"

# Uncomment the following line to change how often to auto-update (in days).
# export UPDATE_ZSH_DAYS=13

# 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.
# The optional three formats: "mm/dd/yyyy"|"dd.mm.yyyy"|"yyyy-mm-dd"
# 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? (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)

source $ZSH/oh-my-zsh.sh

export PATH="/usr/bin:/bin:/usr/sbin:/sbin:/usr/local/bin"
# 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"

# ssh
# export SSH_KEY_PATH="~/.ssh/dsa_id"

# 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"


##############################################################
######################### dereks stuff #######################
##############################################################

export DEV_DIR=~/
# Load node virtual manager
source ~/.nvm/nvm.sh


############################# bash stuff ############################
# destroy all the cache
function clear_pyc(){ find . -name "*.pyc" -exec rm -rf {} \;}
# list dirs after i change
#function cd(){
#    builtin cd "$@" && ls
#}
function untar(){tar -xvzf $@}

############################# Git ############################
alias ca='git add . && git commit -am'
alias gch='git cherry-pick'
alias kill_branch='git branch -D'

########################### Docker  ############################
## GENERAL ##
alias comp='docker compose'
alias comp_prod='docker compose -f docker compose.prod.yml'

dopen(){ /usr/bin/open -a "/Applications/Google Chrome.app" "//$DOCKER_HOST:$1";}

## CONTAINERS ##
toss(){docker run -it --rm $@}
hijack(){docker exec -it $1 bash}
snatch(){docker exec -it $@}
manage_c(){snatch $1 python manage.py ${@:2}}
#Start a container 
attach_c(){toss $1 /bin/bash}
# Used to chown any files i generate with docker
gime() { sudo chown -R $USER:$USER $@;}
# Stop all containers
alias stop_containers='docker stop $(docker ps -q)'
# kill all containers
alias kill_em_all='docker kill $(docker ps -q)'
# remove all non running containers
alias remove_containers='docker rm `docker ps -aq`'
# Removes all containers
alias nuke_containers='docker rm -f $(docker ps -a -q)'
# Essentially resets all container runtimes and leaves nothing
#  - deletes all containers and volumes
alias burn_it_all='nuke_containers && docker volume rm $(docker volume ls -q)'

## IMAGES ##
# Build a template

d_build() { docker build -t="$1" . }
# Removes all images and containers that are not running
alias remove_images='docker rmi `docker images -q`'
#Kill all images and containers that are not running
alias tactical_nuke='remove_containers && remove_images'
alias nuke_volumes='docker volume rm $(docker volume ls -q)'
alias nuke_from_orbit='nuke_containers && docker rmi -f `docker images -q` && docker volume rm `docker volume ls -q`'
alias clean_images='docker rmi $(docker images | grep "^<none>" | awk "{print $3}")'

#Django Docker things
function bootstrap_django(){docker run -it --rm --user "$(id -u):$(id -g)" -v "$PWD":/usr/src/app -w /usr/src/app django django-admin.py startproject $1}

# Backup Volume to directory

function extract_volume(){docker run --rm --volumes-from $1 -v $(pwd):/backup busybox tar cvf /backup/backup.tar /$2}
function restore_volume(){docker run --rm --volumes-from $1 -v $(pwd):/backup busybox bash -c "cd $2 && tar xvf /backup/backup.tar --strip 1"}

########################### Python ############################

## Python Virtualenvs ##


########################### Python ############################

## Python Virtualenvs ##

# /path/to/your/root/virtualenv/no-slash
#VENV_DIR="/home/ubuntu/tools/venv"
#source $VENV_DIR/bin/activate

http() {python -m SimpleHTTPServer $1}
########################### tmux ##########################
alias tm='tmux'
tmat() { tm a -t $1;}
tmswap() {tm switch -t $1;}

# Auto Start
#if [[ -z "$TMUX" ]] then
#  tmux_session='#OMZ'
#
#  if ! tmux has-session -t "$tmux_session" 2> /dev/null; then
#    # Disable the destruction of unattached sessions globally.
#    tmux set-option -g destroy-unattached off &> /dev/null
#
#    # Create a new session.
#    tmux new-session -d -s "$tmux_session"
#
#    # Disable the destruction of the new, unattached session.
#    tmux set-option -t "$tmux_session" destroy-unattached off &> /dev/null
#
#    # Enable the destruction of unattached sessions globally to prevent
#    # an abundance of open, detached sessions.
#    tmux set-option -g destroy-unattached on &> /dev/null
#  fi
#
#  exec tmux new-session -t "$tmux_session"
#fi



########################### gpg-agent ##########################
unset SSH_AGENT_PID
if [ "${gnupg_SSH_AUTH_SOCK_by:-0}" -ne $$ ]; then
  export SSH_AUTH_SOCK="$(gpgconf --list-dirs agent-ssh-socket)"
fi
export GPG_TTY=$(tty)
gpg-connect-agent updatestartuptty /bye >/dev/null

# Color
export COLORTERM=truecolor