Commit d1f34693 by nulltoken

util: Add git__strcmp_cb() wrapper

We don't want direct pointers to the CRT on Windows, we may get stdcall conflicts.
parent f6867e63
...@@ -503,7 +503,7 @@ static int packed_load(git_repository *repo) ...@@ -503,7 +503,7 @@ static int packed_load(git_repository *repo)
ref_cache->packfile = git_hashtable_alloc( ref_cache->packfile = git_hashtable_alloc(
default_table_size, default_table_size,
reftable_hash, reftable_hash,
(git_hash_keyeq_ptr)strcmp); (git_hash_keyeq_ptr)(&git__strcmp_cb));
if (ref_cache->packfile == NULL) { if (ref_cache->packfile == NULL) {
error = GIT_ENOMEM; error = GIT_ENOMEM;
...@@ -1609,7 +1609,7 @@ int git_repository__refcache_init(git_refcache *refs) ...@@ -1609,7 +1609,7 @@ int git_repository__refcache_init(git_refcache *refs)
refs->loose_cache = git_hashtable_alloc( refs->loose_cache = git_hashtable_alloc(
default_table_size, default_table_size,
reftable_hash, reftable_hash,
(git_hash_keyeq_ptr)strcmp); (git_hash_keyeq_ptr)(&git__strcmp_cb));
/* packfile loaded lazily */ /* packfile loaded lazily */
refs->packfile = NULL; refs->packfile = NULL;
...@@ -1752,6 +1752,4 @@ int git_reference__normalize_name(char *buffer_out, size_t out_size, const char ...@@ -1752,6 +1752,4 @@ int git_reference__normalize_name(char *buffer_out, size_t out_size, const char
int git_reference__normalize_name_oid(char *buffer_out, size_t out_size, const char *name) int git_reference__normalize_name_oid(char *buffer_out, size_t out_size, const char *name)
{ {
return normalize_name(buffer_out, out_size, name, 1); return normalize_name(buffer_out, out_size, name, 1);
} }
\ No newline at end of file
...@@ -14,13 +14,6 @@ typedef struct { ...@@ -14,13 +14,6 @@ typedef struct {
git_vector *refs; git_vector *refs;
} transport_local; } transport_local;
static int cmp_refs(const void *a, const void *b)
{
const char *stra = (const char *)a;
const char *strb = (const char *)b;
return strcmp(stra, strb);
}
/* /*
* Try to open the url as a git directory. The direction doesn't * Try to open the url as a git directory. The direction doesn't
* matter in this case because we're calulating the heads ourselves. * matter in this case because we're calulating the heads ourselves.
...@@ -147,7 +140,7 @@ static int local_ls(git_transport *transport, git_headarray *array) ...@@ -147,7 +140,7 @@ static int local_ls(git_transport *transport, git_headarray *array)
return error; return error;
/* Sort the references first */ /* Sort the references first */
git__tsort((void **)refs.strings, refs.count, &cmp_refs); git__tsort((void **)refs.strings, refs.count, &git__strcmp_cb);
/* Add HEAD */ /* Add HEAD */
error = add_ref(GIT_HEAD_FILE, repo, vec); error = add_ref(GIT_HEAD_FILE, repo, vec);
......
...@@ -355,3 +355,16 @@ void **git__bsearch(const void *key, void **base, size_t nmemb, int (*compar)(co ...@@ -355,3 +355,16 @@ void **git__bsearch(const void *key, void **base, size_t nmemb, int (*compar)(co
return NULL; return NULL;
} }
/**
* A strcmp wrapper
*
* We don't want direct pointers to the CRT on Windows, we may
* get stdcall conflicts.
*/
int git__strcmp_cb(const void *a, const void *b)
{
const char *stra = (const char *)a;
const char *strb = (const char *)b;
return strcmp(stra, strb);
}
\ No newline at end of file
...@@ -120,4 +120,6 @@ extern void git__tsort(void **dst, size_t size, int (*cmp)(const void *, const v ...@@ -120,4 +120,6 @@ extern void git__tsort(void **dst, size_t size, int (*cmp)(const void *, const v
extern void **git__bsearch(const void *key, void **base, size_t nmemb, extern void **git__bsearch(const void *key, void **base, size_t nmemb,
int (*compar)(const void *, const void *)); int (*compar)(const void *, const void *));
extern int git__strcmp_cb(const void *a, const void *b);
#endif /* INCLUDE_util_h__ */ #endif /* INCLUDE_util_h__ */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment