#!/bin/bash
#
-# fd-commit - part of the FDroid server tools
+# fd-commit - part of the F-Droid server tools
# Commits updates to apps, allowing you to edit the commit messages
#
-# Copyright (C) 2013 Daniel Martà <mvdan@mvdan.cc>
+# Copyright (C) 2013-2014 Daniel Marti <mvdan@mvdan.cc>
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
commands=()
if [ ! -d metadata ]; then
- [ -d ../metadata ] && cd .. || { echo "No metadata files found!"; exit 2; }
+ if [ -d ../metadata ]; then
+ cd ..
+ else
+ echo "No metadata files found!"
+ exit 2
+ fi
fi
while read line; do
- if [[ "$line" == *M*metadata/*.txt ]]; then
- file=${line##* }
- id=${file##*/}
- id=${id%.txt*}
- if [ $# -gt 0 ]; then
- found=false
- for arg in "$@"; do
- if [ "$id" == "$arg" ]; then
- found=true
- break
- fi
- done
- $found || continue
- fi
+ case "$line" in
+ *'??'*'metadata/'*'.txt') new=true ;;
+ *'M'*'metadata/'*'.txt') new=false ;;
+ *) continue ;;
+ esac
- [ -d metadata/$id ] && extra=metadata/$id || extra=
+ file=${line##* }
+ id=${file##*/}
+ id=${id%.txt*}
- name= autoname=
- while read l; do
- if [[ "$l" == "Auto Name:"* ]]; then
- autoname=${l##*:}
- elif [[ "$l" == "Name:"* ]]; then
- name=${l##*:}
- fi
- done < "$file"
+ if [ $# -gt 0 ]; then
+ case "$@" in
+ *" $id "*) ;; # Middle
+ "$id "*) ;; # Start
+ *" $id") ;; # End
+ "$id") ;; # Alone
+ *) continue ;; # Missing
+ esac
+ fi
- if [ -n "$name" ]; then
- fullname="$name ($id)"
- elif [ -n "$autoname" ]; then
- fullname="$autoname ($id)"
- else
- fullname="$id"
- fi
+ [ -d metadata/$id ] && extra=metadata/$id || extra=
+ name= autoname=
+ while read l; do
+ case "$l" in
+ 'Auto Name:'*) autoname=${l#*:} ;;
+ 'Name:'*) name=${l#*:} ;;
+ 'Summary:'*) break ;;
+ esac
+ done < "$file"
+
+ if [ -n "$name" ]; then
+ fullname="$name"
+ elif [ -n "$autoname" ]; then
+ fullname="$autoname"
+ else
+ fullname="$id"
+ fi
+
+ if $new; then
+ message="New app: $fullname"
+ else
+ onlybuild=true
newbuild=false
- while read l; do
- if [[ "$l" == "+Build:"* ]]; then
- newbuild=true
- build=${l#*:}
- version=${build%%,*}
- build=${build#*,}
- vercode=${build%%,*}
- fi
+ disable=false
+ while read line; do
+ case "$line" in
+ '-Build:'*) onlybuild=false ;;
+ '+Build:'*)
+ $newbuild && onlybuild=false
+ newbuild=true
+ build=${line#*:}
+ version=${build%%,*}
+ build=${build#*,}
+ vercode=${build%%,*}
+ ;;
+ '+'*'disable='*)
+ $newbuild && $onlybuild && disable=true
+ ;;
+ esac
done < <(git diff HEAD -- "$file")
- if $newbuild ; then
- message="Update $fullname to $version ($vercode)"
+ if $newbuild && $onlybuild; then
+ if $disable; then
+ message="Don't update $fullname to $version ($vercode)"
+ else
+ message="Update $fullname to $version ($vercode)"
+ fi
else
message="$fullname:"
fi
-
- message=${message//\"/\\\"}
- commands+=("git commit -m \"$message\" -e -v -- $file $extra")
fi
-done < <(git status --porcelain)
+ message=${message//\"/\\\"}
+ commands+=("git add -- $file $extra && git commit -m \"$message\" -e -v")
+
+done < <(git status --porcelain metadata)
+
+[ -z "$commands" ] && exit 0
+
+git reset >/dev/null
for cmd in "${commands[@]}"; do
eval "$cmd"
+ git reset >/dev/null
done