summaryrefslogtreecommitdiffstats
path: root/color.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2017-02-02 22:36:58 +0100
committerJunio C Hamano <gitster@pobox.com>2017-02-02 22:36:58 +0100
commit85279e86499501be0f046cb9885ad24fbf9d0b8d (patch)
treed272cb15ce42c4b57ad685c133a8d1f36e836995 /color.c
parentMerge branch 'ep/commit-static-buf-cleanup' (diff)
parentdocument behavior of empty color name (diff)
downloadgit-85279e86499501be0f046cb9885ad24fbf9d0b8d.tar.xz
git-85279e86499501be0f046cb9885ad24fbf9d0b8d.zip
Merge branch 'nd/log-graph-configurable-colors'
Some people feel the default set of colors used by "git log --graph" rather limiting. A mechanism to customize the set of colors has been introduced. * nd/log-graph-configurable-colors: document behavior of empty color name color_parse_mem: allow empty color spec log --graph: customize the graph lines with config log.graphColors color.c: trim leading spaces in color_parse_mem() color.c: fix color_parse_mem() with value_len == 0
Diffstat (limited to 'color.c')
-rw-r--r--color.c12
1 files changed, 11 insertions, 1 deletions
diff --git a/color.c b/color.c
index 1b95e6b2a7..dee61557e0 100644
--- a/color.c
+++ b/color.c
@@ -207,7 +207,17 @@ int color_parse_mem(const char *value, int value_len, char *dst)
struct color fg = { COLOR_UNSPECIFIED };
struct color bg = { COLOR_UNSPECIFIED };
- if (!strncasecmp(value, "reset", len)) {
+ while (len > 0 && isspace(*ptr)) {
+ ptr++;
+ len--;
+ }
+
+ if (!len) {
+ dst[0] = '\0';
+ return 0;
+ }
+
+ if (!strncasecmp(ptr, "reset", len)) {
xsnprintf(dst, end - dst, GIT_COLOR_RESET);
return 0;
}