Skip to content

Commit

Permalink
update check_integrity with nicolaiskogheim's patch
Browse files Browse the repository at this point in the history
  • Loading branch information
spacewander committed Jul 29, 2016
1 parent f60f127 commit 5384091
Showing 1 changed file with 38 additions and 15 deletions.
53 changes: 38 additions & 15 deletions check_integrity.sh
@@ -1,38 +1,51 @@
#!/usr/bin/env bash

err() {
echo "$1"
echo >&2 "$1"
exit 1
}

check_bash_script() {
local cmd="git-$1"
test -x "bin/$cmd" || err "bin/$cmd is either non-existent or unexecutable"
shebang=$(head -n 1 "bin/$cmd")
test "$shebang" == "#!/usr/bin/env bash" || \
err "start git-$1 with '#!/usr/bin/env bash'"

test -f "bin/$cmd" \
|| err "Bin/$cmd does not exist"

test -x "bin/$cmd" \
|| err "Run 'chmod +x bin/$cmd' to make it executable"

shebang=$(head -n1 "bin/$cmd")
test "$shebang" == "#!/usr/bin/env bash" \
|| err "Start git-$1 with '#!/usr/bin/env bash'"
}

check_documentation() {
local cmd="git-$1"
test -f "man/$cmd.md" || err "man/$cmd.md required"
test -f "man/$cmd.1" || err "man/$cmd.1 required"
test -f "man/$cmd.html" || err "man/$cmd.html required"
test -f "man/$cmd.md" || err "create man/$cmd.md"

if [ ! -f "man/$cmd.1" ] || [ ! -f "man/$cmd.html" ]
then
err "Run 'make docs' to create man/$cmd.1 and man/$cmd.html"
fi
}

check_Commands_page() {
# These are special cases. All listed together, so we ignore them
local whitelist=('bug' 'chore' 'feature' 'refactor')
for cmd in ${whitelist[*]}; do
test "$1" == "$cmd" && return
done
grep "\- \[\`git $1\`\](#git-$1)" Commands.md > /dev/null && \
grep "^## git $1" Commands.md > /dev/null || \
err "Update Commands.md with git-$1 is required"

grep "\- \[\`git $1\`\](#git-$1)" Commands.md >/dev/null \
|| err "Add git-$1 in the list of commands in Commands.md"

grep "^## git $1" Commands.md >/dev/null \
|| err "Add description of git-$1 in Commands.md"
}

check_completion() {
grep "$1:" etc/git-extras-completion.zsh > /dev/null || \
err "Update git-extras-completion.zsh with git-$1 is required"
err "Add git-$1 to the completion list at the end of etc/git-extras-completion.zsh"
}

check() {
Expand All @@ -42,9 +55,19 @@ check() {
check_completion "$1"
}

test $# == 0 && err "Please give your command name"
usage() {
echo >&2 "Usage: ./check_integrity.sh <command-name> [<command-name2> ...]"
exit 0
}

test $# == 0 && usage

for name in "$@"; do
[[ "$name" == "rscp" || "$name" == "line-summary" ]] && continue
name=${name#git-}
[[ "$name" == "rscp" || "$name" == "line-summary" ]] && echo "Skip command $name" \
&& continue
check "$name"
done
echo 'All is done'

echo 'All done'
exit 0

0 comments on commit 5384091

Please sign in to comment.