Add ability to use branches for plugins
This commit is contained in:
parent
95f78336c3
commit
73a419c599
|
@ -56,7 +56,7 @@ tpm_plugins_list_helper() {
|
||||||
|
|
||||||
# read set -g @plugin "tmux-plugins/tmux-example-plugin" entries
|
# read set -g @plugin "tmux-plugins/tmux-example-plugin" entries
|
||||||
_tmux_conf_contents "full" |
|
_tmux_conf_contents "full" |
|
||||||
awk '/^[ \t]*set(-option)? +-g +@plugin/ { gsub(/'\''/,""); gsub(/'\"'/,""); print $4 }'
|
awk '/^[ \t]*set(-option)? +-g +@plugin/ { gsub(/'\''/,""); gsub(/'\"'/,""); gsub(/#/, " "); print $4","$5 }'
|
||||||
}
|
}
|
||||||
|
|
||||||
# Allowed plugin name formats:
|
# Allowed plugin name formats:
|
||||||
|
|
|
@ -14,8 +14,12 @@ fi
|
||||||
|
|
||||||
clone() {
|
clone() {
|
||||||
local plugin="$1"
|
local plugin="$1"
|
||||||
cd "$(tpm_path)" &&
|
local branch="$2"
|
||||||
GIT_TERMINAL_PROMPT=0 git clone --recursive "$plugin" >/dev/null 2>&1
|
if [ ! -z "$branch" ]; then
|
||||||
|
cd "$(tpm_path)" && GIT_TERMINAL_PROMPT=0 git clone --recursive -b "$branch" "$plugin" >/dev/null 2>&1
|
||||||
|
else
|
||||||
|
cd "$(tpm_path)" && GIT_TERMINAL_PROMPT=0 git clone --recursive "$plugin" >/dev/null 2>&1
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# tries cloning:
|
# tries cloning:
|
||||||
|
@ -23,20 +27,22 @@ clone() {
|
||||||
# 2. expands the plugin name to point to a github repo and tries cloning again
|
# 2. expands the plugin name to point to a github repo and tries cloning again
|
||||||
clone_plugin() {
|
clone_plugin() {
|
||||||
local plugin="$1"
|
local plugin="$1"
|
||||||
clone "$plugin" ||
|
local branch="$2"
|
||||||
clone "https://git::@github.com/$plugin"
|
clone "$plugin" "$branch" ||
|
||||||
|
clone "https://git::@github.com/$plugin" "$branch"
|
||||||
}
|
}
|
||||||
|
|
||||||
# clone plugin and produce output
|
# clone plugin and produce output
|
||||||
install_plugin() {
|
install_plugin() {
|
||||||
local plugin="$1"
|
local plugin="$1"
|
||||||
|
local branch="$2"
|
||||||
local plugin_name="$(plugin_name_helper "$plugin")"
|
local plugin_name="$(plugin_name_helper "$plugin")"
|
||||||
|
|
||||||
if plugin_already_installed "$plugin"; then
|
if plugin_already_installed "$plugin"; then
|
||||||
echo_ok "Already installed \"$plugin_name\""
|
echo_ok "Already installed \"$plugin_name\""
|
||||||
else
|
else
|
||||||
echo_ok "Installing \"$plugin_name\""
|
echo_ok "Installing \"$plugin_name\""
|
||||||
clone_plugin "$plugin" &&
|
clone_plugin "$plugin" "$branch" &&
|
||||||
echo_ok " \"$plugin_name\" download success" ||
|
echo_ok " \"$plugin_name\" download success" ||
|
||||||
echo_err " \"$plugin_name\" download fail"
|
echo_err " \"$plugin_name\" download fail"
|
||||||
fi
|
fi
|
||||||
|
@ -44,8 +50,10 @@ install_plugin() {
|
||||||
|
|
||||||
install_plugins() {
|
install_plugins() {
|
||||||
local plugins="$(tpm_plugins_list_helper)"
|
local plugins="$(tpm_plugins_list_helper)"
|
||||||
for plugin in $plugins; do
|
for plugin_line in $plugins; do
|
||||||
install_plugin "$plugin"
|
local plugin=$(echo $plugin_line | awk -F',' '{print $1}')
|
||||||
|
local branch=$(echo $plugin_line | awk -F',' '{print $2}')
|
||||||
|
install_plugin "$plugin" "$branch"
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue