-
Notifications
You must be signed in to change notification settings - Fork 217
/
Copy pathprofile_helper.sh
executable file
·165 lines (138 loc) · 5.21 KB
/
profile_helper.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
#!/usr/bin/env bash
# ----------------------------------------------------------------------
# Setup config variables and env
# ----------------------------------------------------------------------
# Allow users to optionally configure where their tinted-shell config is
# stored by specifying BASE16_CONFIG_PATH before loading this script
if [ -z $BASE16_CONFIG_PATH ]; then
BASE16_CONFIG_PATH="${XDG_CONFIG_HOME:-$HOME/.config}/tinted-theming"
fi
BASE16_SHELL_COLORSCHEME_PATH="$BASE16_CONFIG_PATH/base16_shell_theme"
# Store the theme name in a file so we aren't reliant on environment
# variables to store this value alone since it can be inaccurate when
# using session managers such as TMUX
BASE16_SHELL_THEME_NAME_PATH="$BASE16_CONFIG_PATH/theme_name"
# Allow users to optionally configure their tinted-shell path and set
# the value if one doesn't exist
if [ -z "$BASE16_SHELL_PATH" ]; then
if [ -n "$BASH_VERSION" ]; then
script_path=${BASH_SOURCE[0]}
elif [ -n "$ZSH_VERSION" ]; then
script_path=${(%):-%x}
fi
BASE16_SHELL_PATH=${script_path%/*}
fi
# If the user hasn't specified a hooks dir path or it is invalid, use
# the existing path
if [ -z "$BASE16_SHELL_HOOKS_PATH" ] && [ ! -d "$BASE16_SHELL_HOOKS_PATH" ]; then
BASE16_SHELL_HOOKS_PATH="$BASE16_SHELL_PATH/hooks"
fi
# Set as a function so these config files can be created later if
# they're missing for some reason
create_config_files()
{
# Create the config path if the path doesn't currently exist
if [ ! -d "$BASE16_CONFIG_PATH" ]; then
mkdir -p "$BASE16_CONFIG_PATH";
fi
# Create a file containing the current theme name
if [ ! -f "$BASE16_SHELL_THEME_NAME_PATH" ]; then
touch "$BASE16_SHELL_THEME_NAME_PATH";
fi
}
create_config_files
# ----------------------------------------------------------------------
# Functions
# ----------------------------------------------------------------------
set_theme()
{
local theme_name="$1"
local force_load="$2"
local script_path="$BASE16_SHELL_PATH/scripts/base16-$theme_name.sh"
local current_theme_name
# Only read from file if it exists
if [ -s "$BASE16_SHELL_THEME_NAME_PATH" ]; then
read current_theme_name < "$BASE16_SHELL_THEME_NAME_PATH"
fi
# Set force_load if one of the required config files don't exist
if [[ \
! -d "$BASE16_CONFIG_PATH" \
|| -z "$current_theme_name" \
|| ! -h "$BASE16_SHELL_COLORSCHEME_PATH" \
]]; then
create_config_files
force_load="true"
fi
# If theme is already sourced, don't rerun the script and hooks,
# unless $force_load is set
if [[ "$theme_name" == "$current_theme_name" && -z $force_load ]]; then
return 0
fi
if [ -z "$theme_name" ]; then
echo "Provide a theme name to set_theme or ensure \
\$BASE16_THEME_DEFAULT is set"
return 1
fi
if [ -e "$BASE16_SHELL_THEME_NAME_PATH" ]; then
echo "$theme_name" >| "$BASE16_SHELL_THEME_NAME_PATH";
fi
# Symlink new colorscheme
ln -fs "$script_path" "$BASE16_SHELL_COLORSCHEME_PATH" >/dev/null
if [ ! -e "$BASE16_SHELL_COLORSCHEME_PATH" ]; then
echo "Attempted symbolic link failed. Ensure \$BASE16_SHELL_PATH \
and \$BASE16_SHELL_COLORSCHEME_PATH are valid paths."
return 2
fi
# Source newly symlinked file
[ -f "$BASE16_SHELL_COLORSCHEME_PATH" ] \
&& . "$BASE16_SHELL_COLORSCHEME_PATH"
if [ -d "${BASE16_SHELL_HOOKS_PATH}" ]; then
for hook in $BASE16_SHELL_HOOKS_PATH/*.sh; do
[ -x "$hook" ] && . "$hook"
done
unset hook
fi
unset theme_name
unset script_path
unset current_theme_name
}
# ----------------------------------------------------------------------
# Execution
# ----------------------------------------------------------------------
# Reload the $BASE16_SHELL_COLORSCHEME_PATH when the shell is reset
alias reset="command reset \
&& [ -f $BASE16_SHELL_COLORSCHEME_PATH ] \
&& . $BASE16_SHELL_COLORSCHEME_PATH"
# Set base16_* aliases
for script_path in "$BASE16_SHELL_PATH"/scripts/base16*.sh; do
script_name=${script_path##*/}
script_name=${script_name%.sh}
theme_name=${script_name#base16-} # eg: solarized-light
function_name="base16_${theme_name}"
alias $function_name="set_theme \"${theme_name}\""
done;
# unset loop variables to not leak to user's shell
unset script_path script_name theme_name function_name
# If $BASE16_THEME is set, this has already been loaded. This guards
# against a bug where this script is sourced two or more times.
if [ -n "$BASE16_THEME" ]; then
return 0
fi
# Load the active theme
# If the theme name can be easily retrieved
read current_theme_name < "$BASE16_SHELL_THEME_NAME_PATH"
if [ -n "$current_theme_name" ]; then
set_theme "$current_theme_name" "true"
# Else extract from the colorscheme file
elif [ -e "$BASE16_SHELL_COLORSCHEME_PATH" ]; then
# Get the active theme name from the export variable in the script
current_theme_name=$(grep 'export BASE16_THEME' "$BASE16_SHELL_COLORSCHEME_PATH")
current_theme_name=${current_theme_name#*=}
set_theme "$current_theme_name" "true"
# If a colorscheme file doesn't exist and BASE16_THEME_DEFAULT is set,
# then create the colorscheme file based on the BASE16_THEME_DEFAULT
# scheme name
elif [ -n "$BASE16_THEME_DEFAULT" ]; then
set_theme "$BASE16_THEME_DEFAULT" "true"
fi
unset current_theme_name