Code

dir.c(common_prefix): Fix two bugs
authorJohannes Schindelin <Johannes.Schindelin@gmx.de>
Mon, 23 Apr 2007 08:21:25 +0000 (10:21 +0200)
committerJunio C Hamano <junkio@cox.net>
Mon, 23 Apr 2007 08:44:00 +0000 (01:44 -0700)
commitc7f34c180b7117cf60ad12a8b180eed33716e390
treec5851c48ba95fd20ddc99c8e11e3ecc223e7c65c
parent97317061c6799765c7f2f83d8e3f4f74df469793
dir.c(common_prefix): Fix two bugs

The function common_prefix() is used to find the common subdirectory of
a couple of pathnames. When checking if the next pathname matches up with
the prefix, it incorrectly checked the whole path, not just the prefix
(including the slash). Thus, the expensive part of the loop was executed
always.

The other bug is more serious: if the first and the last pathname in the
list have a longer common prefix than the common prefix for _all_ pathnames
in the list, the longer one would be chosen. This bug was probably hidden
by the fact that bash's wildcard expansion sorts the results, and the code
just so happens to work with sorted input.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>
dir.c
t/t3700-add.sh