aboutsummaryrefslogtreecommitdiff
path: root/tests/test19.c
diff options
context:
space:
mode:
Diffstat (limited to 'tests/test19.c')
-rw-r--r--tests/test19.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/tests/test19.c b/tests/test19.c
new file mode 100644
index 000000000..aec898f8f
--- /dev/null
+++ b/tests/test19.c
@@ -0,0 +1,66 @@
+#include "uthash.h"
+#include <stdlib.h> /* malloc */
+#include <stdio.h> /* printf */
+
+typedef struct example_user_t {
+ int id;
+ int cookie;
+ UT_hash_handle hh;
+ UT_hash_handle alth;
+} example_user_t;
+
+static int ascending_sort(void *_a, void *_b)
+{
+ example_user_t *a = (example_user_t*)_a;
+ example_user_t *b = (example_user_t*)_b;
+ if (a->id == b->id) {
+ return 0;
+ }
+ return (a->id < b->id) ? -1 : 1;
+}
+
+static int descending_sort(void *_a, void *_b)
+{
+ example_user_t *a = (example_user_t*)_a;
+ example_user_t *b = (example_user_t*)_b;
+ if (a->id == b->id) {
+ return 0;
+ }
+ return (a->id < b->id) ? 1 : -1;
+}
+
+int main()
+{
+ int i;
+ example_user_t *user, *users=NULL, *altusers=NULL;
+
+ /* create elements */
+ for(i=0; i<1000; i++) {
+ user = (example_user_t*)malloc(sizeof(example_user_t));
+ if (user == NULL) {
+ exit(-1);
+ }
+ user->id = i;
+ user->cookie = i*i;
+ if (i<10) {
+ HASH_ADD_INT(users,id,user);
+ }
+ HASH_ADD(alth,altusers,id,sizeof(int),user);
+ }
+
+ printf("sorting users ascending\n");
+ HASH_SRT(hh,users,ascending_sort);
+ for(user=users; user!=NULL; user=(example_user_t*)user->hh.next) {
+ printf("user %d\n", user->id);
+ }
+
+ printf("sorting altusers descending\n");
+ HASH_SRT(alth,altusers,descending_sort);
+ for(user=altusers; user!=NULL; user=(example_user_t*)user->alth.next) {
+ printf("altuser %d\n", user->id);
+ }
+
+ /* HASH_FSCK(hh,users); */
+ /* HASH_FSCK(alth,altusers); */
+ return 0;
+}