summaryrefslogtreecommitdiff
path: root/git-shell-commands/change-description
diff options
context:
space:
mode:
authorLuke Shumaker <LukeShu@sbcglobal.net>2014-06-02 13:48:51 -0400
committerLuke Shumaker <LukeShu@sbcglobal.net>2014-06-02 13:48:51 -0400
commite3f6b8e3246f89c6df4052006d18df542721c16e (patch)
tree481143d61ead547b2e76ac66bc07cc533f2f7f6e /git-shell-commands/change-description
parent296184cb6a3f34b2e1f0ced37e862f1fcae7cc0c (diff)
lukeshu-ify the git-shell-commands
mostly, handle escaping repo names consistently-ish
Diffstat (limited to 'git-shell-commands/change-description')
-rwxr-xr-xgit-shell-commands/change-description13
1 files changed, 10 insertions, 3 deletions
diff --git a/git-shell-commands/change-description b/git-shell-commands/change-description
index 730777c..60db0ac 100755
--- a/git-shell-commands/change-description
+++ b/git-shell-commands/change-description
@@ -1,4 +1,4 @@
-#!/bin/sh
+#!/bin/bash
# * change-description
# Cambia la descripcion del projecto, necesita archivo description en el proyecto
# ssh git@host change-description repo "description"
@@ -7,6 +7,13 @@ set -e
repo=$1; shift
-test -d ${repo}.git && echo "${@}" > ${repo}.git/description
+repo="$(sed -r 's,^/*,,' <<<"$repo")"
+_repo="$(sed -r -e '/(^|\/)\.\.($|\/)/d' -e "s,[^A-Za-z0-9\./_~-],,g" <<<"$repo")"
+test "$repo" = "$_repo" || { printf 'Illegal name: %s\n' "${repo}"; exit 1; }
-exit $?
+if test -d "$repo".git; then
+ echo "${*}" > "${repo}".git/description
+else
+ printf 'Does not exist: %s\n' "${repo}"
+ exit 1
+fi