Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/libgit2.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorVicent Marti <tanoku@gmail.com>2011-07-07 03:46:20 +0400
committerVicent Marti <tanoku@gmail.com>2011-07-07 04:54:07 +0400
commitde18f276683a5cf3d85d001f6521e52c8c802e60 (patch)
tree01db449c1fa2d11568aca66bf4a5ef9d1a5c60f3 /tests
parentc63aa494595a6d6e6d97cfa1bbc1741a0b2e0cc6 (diff)
vector: Timsort all of the things
Drop the GLibc implementation of Merge Sort and replace it with Timsort. The algorithm has been tuned to work on arrays of pointers (void **), so there's no longer a need to abstract the byte-width of each element in the array. All the comparison callbacks now take pointers-to-elements, not pointers-to-pointers, so there's now one less level of dereferencing. E.g. int index_cmp(const void *a, const void *b) { - const git_index_entry *entry_a = *(const git_index_entry **)(a); + const git_index_entry *entry_a = (const git_index_entry *)(a); The result is up to a 40% speed-up when sorting vectors. Memory usage remains lineal. A new `bsearch` implementation has been added, whose callback also supplies pointer-to-elements, to uniform the Vector API again.
Diffstat (limited to 'tests')
-rw-r--r--tests/t00-core.c5
1 files changed, 1 insertions, 4 deletions
diff --git a/tests/t00-core.c b/tests/t00-core.c
index 7bcc77aeb..660f10c89 100644
--- a/tests/t00-core.c
+++ b/tests/t00-core.c
@@ -75,10 +75,7 @@ END_TEST
static int test_cmp(const void *a, const void *b)
{
- int n1 = *(int *)a;
- int n2 = *(int *)b;
-
- return n1 - n2;
+ return a - b;
}
BEGIN_TEST(vector2, "remove duplicates")