diff options
author | Russell Belfer <rb@github.com> | 2013-06-17 10:46:15 -0700 |
---|---|---|
committer | Russell Belfer <rb@github.com> | 2013-06-17 10:46:15 -0700 |
commit | c09810eedfd89923e5bda25d0c98def292dee732 (patch) | |
tree | 668d7196ff3b01c553bbe0c5dd5712e861b6cfc6 /src/util.c | |
parent | 09c2f91c150a4862c9189d9e08d0dc111d4d706c (diff) | |
parent | f4183347607c85d3fbe02e8591d9393a011ecdf2 (diff) | |
download | libgit2-c09810eedfd89923e5bda25d0c98def292dee732.tar.gz |
Merge pull request #1651 from arrbee/status_indexed_updates
Status indexed updates
Diffstat (limited to 'src/util.c')
-rw-r--r-- | src/util.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/util.c b/src/util.c index da15a039d..c543a3d21 100644 --- a/src/util.c +++ b/src/util.c @@ -279,6 +279,28 @@ int git__strcasecmp(const char *a, const char *b) return (tolower(*a) - tolower(*b)); } +int git__strcasesort_cmp(const char *a, const char *b) +{ + int cmp = 0; + + while (*a && *b) { + if (*a != *b) { + if (tolower(*a) != tolower(*b)) + break; + /* use case in sort order even if not in equivalence */ + if (!cmp) + cmp = (int)(*(const uint8_t *)a) - (int)(*(const uint8_t *)b); + } + + ++a, ++b; + } + + if (*a || *b) + return tolower(*a) - tolower(*b); + + return cmp; +} + int git__strncmp(const char *a, const char *b, size_t sz) { while (sz && *a && *b && *a == *b) |