Skip to content

Commit

Permalink
Merge branch 'maint'
Browse files Browse the repository at this point in the history
* maint:
  Fix parsing numeric color values
  INSTALL: git-merge no longer uses cpio
  • Loading branch information
gitster committed Feb 6, 2008
2 parents e62a641 + a0cf49c commit b828fef
Show file tree
Hide file tree
Showing 3 changed files with 72 additions and 3 deletions.
4 changes: 2 additions & 2 deletions INSTALL
Original file line number Diff line number Diff line change
Expand Up @@ -79,8 +79,8 @@ Issues of note:
- "perl" and POSIX-compliant shells are needed to use most of
the barebone Porcelainish scripts.

- "cpio" is used by git-merge for saving and restoring the index,
and by git-clone when doing a local (possibly hardlinked) clone.
- "cpio" is used by git-clone when doing a local (possibly
hardlinked) clone.

- Some platform specific issues are dealt with Makefile rules,
but depending on your specific installation, you may not
Expand Down
2 changes: 1 addition & 1 deletion color.c
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ static int parse_color(const char *name, int len)
return i - 1;
}
i = strtol(name, &end, 10);
if (*name && !*end && i >= -1 && i <= 255)
if (end - name == len && i >= -1 && i <= 255)
return i;
return -2;
}
Expand Down
69 changes: 69 additions & 0 deletions t/t4026-color.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,69 @@
#!/bin/sh
#
# Copyright (c) 2008 Timo Hirvonen
#

test_description='Test diff/status color escape codes'
. ./test-lib.sh

color()
{
git config diff.color.new "$1" &&
test "`git config --get-color diff.color.new`" = "$2"
}

invalid_color()
{
git config diff.color.new "$1" &&
test -z "`git config --get-color diff.color.new 2>/dev/null`"
}

test_expect_success 'reset' '
color "reset" "[m"
'

test_expect_success 'attribute before color name' '
color "bold red" "[1;31m"
'

test_expect_success 'color name before attribute' '
color "red bold" "[1;31m"
'

test_expect_success 'attr fg bg' '
color "ul blue red" "[4;34;41m"
'

test_expect_success 'fg attr bg' '
color "blue ul red" "[4;34;41m"
'

test_expect_success 'fg bg attr' '
color "blue red ul" "[4;34;41m"
'

test_expect_success '256 colors' '
color "254 bold 255" "[1;38;5;254;48;5;255m"
'

test_expect_success 'color too small' '
invalid_color "-2"
'

test_expect_success 'color too big' '
invalid_color "256"
'

test_expect_success 'extra character after color number' '
invalid_color "3X"
'

test_expect_success 'extra character after color name' '
invalid_color "redX"
'

test_expect_success 'extra character after attribute' '
invalid_color "dimX"
'

test_done

0 comments on commit b828fef

Please sign in to comment.