diff options
| author | Jeff King <peff@peff.net> | 2008-03-12 17:29:57 -0400 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-03-12 21:10:00 -0700 | 
| commit | 40a7ce64e146c79a966a8494d3a7e85826d7f4e9 (patch) | |
| tree | 3349632b86ba74d796700a57a8bae16386ebbfc2 /git-bisect.sh | |
| parent | a6828f536119c3288b0be772e3870f1a464d017d (diff) | |
| download | git-40a7ce64e146c79a966a8494d3a7e85826d7f4e9.tar.gz | |
tr portability fixes
Specifying character ranges in tr differs between System V
and POSIX. In System V, brackets are required (e.g.,
'[A-Z]'), whereas in POSIX they are not.
We can mostly get around this by just using the bracket form
for both sets, as in:
  tr '[A-Z] '[a-z]'
in which case POSIX interpets this as "'[' becomes '['",
which is OK.
However, this doesn't work with multiple sequences, like:
  # rot13
  tr '[A-Z][a-z]' '[N-Z][A-M][n-z][a-m]'
where the POSIX version does not behave the same as the
System V version. In this case, we must simply enumerate the
sequence.
This patch fixes problematic uses of tr in git scripts and
test scripts in one of three ways:
  - if a single sequence, make sure it uses brackets
  - if multiple sequences, enumerate
  - if extra brackets (e.g., tr '[A]' 'a'), eliminate
    brackets
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'git-bisect.sh')
| -rwxr-xr-x | git-bisect.sh | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/git-bisect.sh b/git-bisect.sh index 2c32d0b9eb..48fb92d612 100755 --- a/git-bisect.sh +++ b/git-bisect.sh @@ -293,14 +293,14 @@ bisect_next() {  	bisect_next_check good  	skip=$(git for-each-ref --format='%(objectname)' \ -		"refs/bisect/skip-*" | tr '[\012]' ' ') || exit +		"refs/bisect/skip-*" | tr '\012' ' ') || exit  	BISECT_OPT=''  	test -n "$skip" && BISECT_OPT='--bisect-all'  	bad=$(git rev-parse --verify refs/bisect/bad) &&  	good=$(git for-each-ref --format='^%(objectname)' \ -		"refs/bisect/good-*" | tr '[\012]' ' ') && +		"refs/bisect/good-*" | tr '\012' ' ') &&  	eval="git rev-list --bisect-vars $BISECT_OPT $good $bad --" &&  	eval="$eval $(cat "$GIT_DIR/BISECT_NAMES")" &&  	eval=$(filter_skipped "$eval" "$skip") && | 
