aboutsummaryrefslogtreecommitdiff
path: root/git-tag.sh
diff options
context:
space:
mode:
authorJunio C Hamano <junkio@cox.net>2005-10-15 17:10:14 -0700
committerJunio C Hamano <junkio@cox.net>2005-10-15 17:10:14 -0700
commit652d5dc6c0aef842eafcd9d2f73a4836d20734e2 (patch)
tree81f2fb438b53db399041ce72c8b4894bd7729568 /git-tag.sh
parent494245d6d1ad365e9b8d76668ed7ff3f888057b1 (diff)
downloadgit-652d5dc6c0aef842eafcd9d2f73a4836d20734e2.tar.xz
git-check-ref-format: reject funny ref names.
Update check_ref_format() function to reject ref names that: * has a path component that begins with a ".", or * has a double dots "..", or * has ASCII control character, "~", "^", ":" or SP, anywhere, or * ends with a "/". Use it in 'git-checkout -b', 'git-branch', and 'git-tag' to make sure that newly created refs are well-formed. Signed-off-by: Junio C Hamano <junkio@cox.net>
Diffstat (limited to 'git-tag.sh')
-rwxr-xr-xgit-tag.sh2
1 files changed, 2 insertions, 0 deletions
diff --git a/git-tag.sh b/git-tag.sh
index 400bdb9843..11b0492ba8 100755
--- a/git-tag.sh
+++ b/git-tag.sh
@@ -46,6 +46,8 @@ if [ -e "$GIT_DIR/refs/tags/$name" -a -z "$force" ]; then
die "tag '$name' already exists"
fi
shift
+git-check-ref-format "tags/$name" ||
+ die "we do not like '$name' as a tag name."
object=$(git-rev-parse --verify --default HEAD "$@") || exit 1
type=$(git-cat-file -t $object) || exit 1