summaryrefslogtreecommitdiff
path: root/src/util.c
diff options
context:
space:
mode:
authorRussell Belfer <rb@github.com>2013-06-17 10:46:15 -0700
committerRussell Belfer <rb@github.com>2013-06-17 10:46:15 -0700
commitc09810eedfd89923e5bda25d0c98def292dee732 (patch)
tree668d7196ff3b01c553bbe0c5dd5712e861b6cfc6 /src/util.c
parent09c2f91c150a4862c9189d9e08d0dc111d4d706c (diff)
parentf4183347607c85d3fbe02e8591d9393a011ecdf2 (diff)
downloadlibgit2-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.c22
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)