-#!/bin/sh
+#!/bin/bash
#
# fd-commit - part of the FDroid server tools
# Commits updates to apps, allowing you to edit the commit messages
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
-commands=""
+commands=()
if [ ! -d metadata ]; then
if [ -d ../metadata ]; then
fi
while read line; do
- [ -z "$line" ] && continue
-
- case "$line" in
- *\?\?*metadata/*.txt) new=true ;;
- *M*metadata/*.txt) new=false ;;
- esac
-
+ if [[ "$line" == *\?\?*metadata/*.txt ]]; then
+ new=true
+ elif [[ "$line" == *M*metadata/*.txt ]]; then
+ new=false
+ fi
file=${line##* }
+
id=${file##*/}
id=${id%.txt*}
-
if [ $# -gt 0 ]; then
case "$@" in
*" $id "*) ;; # Middle
name= autoname=
while read l; do
- case "$l" in
- 'Auto Name:'*) autoname=${l#*:} ;;
- 'Name:'*) name=${l#*:} ;;
- esac
+ if [[ "$l" == "Auto Name:"* ]]; then
+ autoname=${l#*:}
+ elif [[ "$l" == "Name:"* ]]; then
+ name=${l#*:}
+ fi
done < "$file"
if [ -n "$name" ]; then
onlybuild=true
newbuild=false
disable=false
-
while read l; do
- case "$l" in
- *"Maintainer Notes:"*) break ;;
- "-Build:"*) onlybuild=false ;;
- "+Build:"*)
- $newbuild && onlybuild=false
- newbuild=true
- build=${l#*:}
- version=${build%%,*}
- build=${build#*,}
- vercode=${build%%,*}
- ;;
- '+'*"disable="*)
- $newbuild && $onlybuild && disable=true
- ;;
- esac
- done << EOF
- $(git diff HEAD -- "$file")
-EOF
+ if [[ "$l" == *"Maintainer Notes:"* ]]; then
+ break
+ fi
+ if [[ "$l" == "-Build:"* ]]; then
+ onlybuild=false
+ elif [[ "$l" == "+Build:"* ]]; then
+ if $newbuild; then
+ onlybuild=false
+ fi
+ newbuild=true
+ build=${l#*:}
+ version=${build%%,*}
+ build=${build#*,}
+ vercode=${build%%,*}
+ elif $newbuild && $onlybuild && [[ "$l" == "+"*"disable="* ]]; then
+ disable=true
+ fi
+ done < <(git diff HEAD -- "$file")
if $newbuild && $onlybuild; then
if $disable; then
fi
message=${message//\"/\\\"}
- commands="$commands%%git add -- $file $extra && git commit -m \"$message\" -e -v"
-
-done << EOF
-$(git status --porcelain metadata)
-EOF
+ commands+=("git add -- $file $extra && git commit -m \"$message\" -e -v")
+done < <(git status --porcelain metadata)
-[ -z "$commands" ] && exit 0
+[[ -z $commands ]] && exit 0
git reset >/dev/null
-IFS='%%'
-for cmd in $commands; do
- [ -z "$cmd" ] && continue
- eval $cmd
+for cmd in "${commands[@]}"; do
+ eval "$cmd"
git reset >/dev/null
done