Skip to content

Commit

Permalink
Add branches support to update_plugin.sh
Browse files Browse the repository at this point in the history
  • Loading branch information
illia-shkroba committed Nov 3, 2024
1 parent 99469c4 commit fcbf121
Showing 1 changed file with 43 additions and 6 deletions.
49 changes: 43 additions & 6 deletions scripts/update_plugin.sh
Original file line number Diff line number Diff line change
Expand Up @@ -17,17 +17,52 @@ fi
# from now on ignore first script argument
shift

is_branch() {
git show-ref --quiet --branches "$1" 2> /dev/null
case "$?" in
129) git show-ref --quiet --heads "$1" 2> /dev/null ;;
*) return "$?" ;;
esac
}

pull_changes() {
local plugin="$1"
local branch="${2:-"$(git remote show origin | sed -n '/HEAD branch/s/.*: //p')"}"
local plugin_path="$(plugin_path_helper "$plugin")"
cd "$plugin_path" &&
GIT_TERMINAL_PROMPT=0 git pull &&
GIT_TERMINAL_PROMPT=0 git submodule update --init --recursive
(
set -e

cd "$plugin_path"
export GIT_TERMINAL_PROMPT=0

# Since `clone()` in *install_plugins.sh* uses `--single-branch`, the
# `remote.origin.fetch` is set to `+refs/tags/<BRANCH>:refs/tags/<BRANCH>`.
# Thus, no other branch could be used, but only the one that was used
# during the `clone()`.
#
# The following `git config` allows to use other branches that are
# available on remote.
git config --replace-all remote.origin.fetch '+refs/heads/*:refs/remotes/origin/*'
# Fetch recent branches/tags/commits.
# `--tags` ensures that tags from the remote are fetched.
# `--force` ensures that updated tags do not cause errors during fetch.
git fetch --force --tags
# `checkout` should be used after `fetch`.
git checkout "$branch"
# `merge` can only be used when HEAD points to a branch.
if is_branch "$branch"
then
git merge --ff-only
fi

git submodule update --init --recursive
)
}

update() {
local plugin="$1" output
output=$(pull_changes "$plugin" 2>&1)
local branch="$2"
output=$(pull_changes "$plugin" "$branch" 2>&1)
if (( $? == 0 )); then
echo_ok " \"$plugin\" update success"
echo_ok "$(echo "$output" | sed -e 's/^/ | /')"
Expand All @@ -44,9 +79,10 @@ update_all() {
for plugin in $plugins; do
IFS='#' read -ra plugin <<< "$plugin"
local plugin_name="$(plugin_name_helper "${plugin[0]}")"
local branch="${plugin[1]}"
# updating only installed plugins
if plugin_already_installed "$plugin_name"; then
update "$plugin_name" &
update "$plugin_name" "$branch" &
fi
done
wait
Expand All @@ -57,8 +93,9 @@ update_plugins() {
for plugin in $plugins; do
IFS='#' read -ra plugin <<< "$plugin"
local plugin_name="$(plugin_name_helper "${plugin[0]}")"
local branch="${plugin[1]}"
if plugin_already_installed "$plugin_name"; then
update "$plugin_name" &
update "$plugin_name" "$branch" &
else
echo_err "$plugin_name not installed!" &
fi
Expand Down

0 comments on commit fcbf121

Please sign in to comment.