-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathinteractive.sh
executable file
·201 lines (176 loc) · 6.49 KB
/
interactive.sh
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
#!/usr/bin/env bash
# shellcheck source=/dev/null
. "$HOME"/.shells/.all/interactive.sh
###############################################################################
# Bash options #
###############################################################################
# Enable some Bash features when possible:
# * If `autocd` is set, a command name that is the name of a directory is executed
# as if it were the argument to the cd command.
# * If `cdspell` is set, bash autocorrects typos in path names when using `cd`
# * If `checkwinsize` is set, bash checks the window size after each command and, if necessary,
# updates the values of LINES and COLUMNS.
for option in autocd cdspell checkwinsize; do
shopt -s "$option" 2>/dev/null
done
###############################################################################
# Completion #
###############################################################################
# enable programmable completion features (you don't need to enable
# this, if it's already enabled in /etc/bash.bashrc and /etc/profile
# sources /etc/bash.bashrc).
if ! shopt -oq posix; then
if [[ -f /usr/share/bash-completion/bash_completion ]]; then
# shellcheck source=/dev/null
. /usr/share/bash-completion/bash_completion
elif [[ -f /etc/bash_completion ]]; then
# shellcheck source=/dev/null
. /etc/bash_completion
elif [[ -f /usr/local/etc/bash_completion ]]; then
# shellcheck source=/dev/null
. /usr/local/etc/bash_completion
fi
fi
# Add tab completion for many Bash commands on macOS
if command -v brew &>/dev/null; then
BREW_PREFIX="$(brew --prefix)"
BASH_COMPLETION_PATH="$BREW_PREFIX"/etc/profile.d/bash_completion.sh
if [ -f "$BASH_COMPLETION_PATH" ]; then
export BASH_COMPLETION_COMPAT_DIR="$BREW_PREFIX"/etc/bash_completion.d
# shellcheck source=/dev/null
. "$BASH_COMPLETION_PATH"
fi
BASH_COMPLETION_PATH="$BREW_PREFIX"/Caskroom/google-cloud-sdk/latest/google-cloud-sdk/completion.bash.inc
# Enable shell command completion for gcloud SDK
if [ -f "$BASH_COMPLETION_PATH" ]; then
# shellcheck source=/dev/null
. "$BASH_COMPLETION_PATH"
fi
unset BASH_COMPLETION_PATH
unset BREW_PREFIX
fi
# Enable tab completion for `g` by marking it as an alias for `git`
if type _git &>/dev/null; then
complete -o default -o nospace -F _git g
fi
# Add tab completion for `defaults read|write NSGlobalDomain`
# You could just use `-g` instead, but I like being explicit
if command -v defaults &>/dev/null; then
complete -W "NSGlobalDomain" defaults
fi
# shellcheck source=/dev/null
command -v kubectl >/dev/null 2>&1 && . <(kubectl completion bash)
###############################################################################
# Bash prompt #
###############################################################################
# Shell prompt based on the Solarized Dark theme.
# Screenshot: http://i.imgur.com/EkEtphC.png
# Heavily inspired by @necolas’s prompt: https://github.com/necolas/dotfiles
# iTerm → Profiles → Text → use 13pt Monaco with 1.1 vertical spacing.
prompt_git() {
local s=''
local branchName=''
# Check if the current directory is in a Git repository.
git rev-parse --is-inside-work-tree &>/dev/null || return
# Check for what branch we’re on.
# Get the short symbolic ref. If HEAD isn’t a symbolic ref, get a
# tracking remote branch or tag. Otherwise, get the
# short SHA for the latest commit, or give up.
branchName="$(git symbolic-ref --quiet --short HEAD 2>/dev/null ||
git describe --all --exact-match HEAD 2>/dev/null ||
git rev-parse --short HEAD 2>/dev/null ||
echo '(unknown)')"
# Early exit for Chromium & Blink repo, as the dirty check takes too long.
# Thanks, @paulirish!
# https://github.com/paulirish/dotfiles/blob/dd33151f/.bash_prompt#L110-L123
repoUrl="$(git config --get remote.origin.url)"
if grep -q 'chromium/src.git' <<<"${repoUrl}"; then
s+='*'
else
# Check for uncommitted changes in the index.
if ! git diff --quiet --ignore-submodules --cached; then
s+='+'
fi
# Check for unstaged changes.
if ! git diff-files --quiet --ignore-submodules --; then
s+='!'
fi
# Check for untracked files.
if [ -n "$(git ls-files --others --exclude-standard)" ]; then
s+='?'
fi
# Check for stashed files.
if git rev-parse --verify refs/stash &>/dev/null; then
s+='$'
fi
fi
[ -n "${s}" ] && s=" [${s}]"
echo -e "${1}${branchName}${2}${s}"
}
if tput setaf 1 &>/dev/null; then
tput sgr0 # reset colors
bold=$(tput bold)
reset=$(tput sgr0)
# Solarized colors, taken from http://git.io/solarized-colors.
black=$(tput setaf 0)
blue=$(tput setaf 33)
cyan=$(tput setaf 37)
green=$(tput setaf 64)
orange=$(tput setaf 166)
purple=$(tput setaf 125)
red=$(tput setaf 124)
violet=$(tput setaf 61)
white=$(tput setaf 15)
yellow=$(tput setaf 136)
else
bold=''
reset="\e[0m"
# Unused variables left for future use
# shellcheck disable=SC2034
black="\e[1;30m"
# Unused variables left for future use
# shellcheck disable=SC2034
blue="\e[1;34m"
# Unused variables left for future use
# shellcheck disable=SC2034
cyan="\e[1;36m"
# Unused variables left for future use
# shellcheck disable=SC2034
green="\e[1;32m"
# Unused variables left for future use
# shellcheck disable=SC2034
orange="\e[1;33m"
# Unused variables left for future use
# shellcheck disable=SC2034
purple="\e[1;35m"
red="\e[1;31m"
violet="\e[1;35m"
white="\e[1;37m"
yellow="\e[1;33m"
fi
# Highlight the user name when logged in as root.
if [[ "${USER}" == "root" ]]; then
userStyle="${red}"
else
userStyle="${orange}"
fi
# Highlight the hostname when connected via SSH.
if [[ "${SSH_TTY}" ]]; then
hostStyle="${bold}${red}"
else
hostStyle="${yellow}"
fi
# Set the terminal title and prompt.
PS1="\[\033]0;\W\007\]" # working directory base name
PS1+="\[${bold}\]\n" # newline
PS1+="\[${userStyle}\]\u" # username
PS1+="\[${white}\] at "
PS1+="\[${hostStyle}\]$(hostname -f)" # host
PS1+="\[${white}\] in "
PS1+="\[${green}\]\w" # working directory full path
PS1+="\$(prompt_git \"\[${white}\] on \[${violet}\]\" \"\[${blue}\]\")" # Git repository details
PS1+="\n"
PS1+="\[${white}\]\$ \[${reset}\]" # `$` (and reset color)
export PS1
PS2="\[${yellow}\]→ \[${reset}\]"
export PS2