Skip to content
Open
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
33 changes: 29 additions & 4 deletions umpf
Original file line number Diff line number Diff line change
Expand Up @@ -421,6 +421,25 @@ nice_branch() {
read -r -a replies < <(sed -r -n 's,^(remotes/([^/]*)/|heads/)?(.*),\3 \2,p' <<< "${1}")
}

add_choice() {
choices+=("$1")
choice_descs+=("$2")
}

print_choices() {
local i default choice
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

choice is unused.

default="$1"
for i in "${!choices[@]}"; do
if [ "${default}" = "${choices[${i}]}" ]; then
echo -en '\e[1m'
echo "${choices[${i}]}) ${choice_descs[${i}]}"
echo -en '\e[0m'
else
echo "${choices[${i}]}) ${choice_descs[${i}]}"
fi;
done;
}

read_interactive() {
local prompt="${1}" def="${2}"
if ${DEFAULT} && [ -n "${def}" ]; then
Expand Down Expand Up @@ -456,14 +475,17 @@ find_branch_rev() {
info "Branch not found for '${remote}'. Choose alternative branch:"
fi
local i=0 def=0 choice
# shellcheck disable=SC2034
local -a choices choices_descs
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

While you can declare local variable in the middle of a function inside a loop, they will not actually go out of scope at the end of the loop body.
So if the user gives an invalid response, all the choices are shown twice.

You need to explicitly initialize the variables, e.g. choices=()

for branch in "${branches[@]}"; do
nice_branch "${branch}"
echo "${i}) ${replies[1]:+${replies[1]}/}${replies[0]}"
add_choice "${i}" "${replies[1]:+${replies[1]}/}${replies[0]}"
if [ "${GIT_FALLBACK_REMOTE}" == "${replies[1]}/" ]; then
def="${i}"
fi
i=$((i+1))
done
print_choices "${def}"
read_interactive "branch number" "${def}"
nice_branch "${branches[${choice}]}"
remote="${replies[1]:-refs/heads}/"
Expand Down Expand Up @@ -1706,15 +1728,18 @@ apply_to_topic() {

while [ -z "${topic}" ]; do
local i=0 choice default
# shellcheck disable=SC2034
local -a choices choice_descs
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Same here.

for branch in "${branch_names[@]}"; do
echo "${i}) ${branch}"
add_choice "${i}" "${branch}"
if git log --pretty="format:%s" "${base}..${branches[${i}]}" | grep -q "^${match}$"; then
default="${i}"
fi
i=$((i+1))
done
echo "s) show patch"
echo "x) skip patch"
add_choice "s" "show patch"
add_choice "x" "skip patch"
print_choices "${default}"
read_interactive "Branch" "${default}"
case "${choice}" in
s)
Expand Down