/* $Id$ */ #include "test.h" #if INCLUDE_RBTREE_TEST #include #define LOOP 32 #define MIN_COUNT 64 #define MAX_COUNT (LOOP * MIN_COUNT) #define STRSIZE 16 #define THIS_FILE "rbtree_test" typedef struct node_key { pj_uint32_t hash; char str[STRSIZE]; } node_key; static int compare_node(const node_key *k1, const node_key *k2) { if (k1->hash == k2->hash) { return strcmp(k1->str, k2->str); } else { return k1->hash < k2->hash ? -1 : 1; } } void randomize_string(char *str, int len) { int i; for (i=0; ikey,(node_key*)it->key)>=0) { ++err; PJ_LOG(3, (THIS_FILE, "Error: %s >= %s", (char*)prev->user_data, (char*)it->user_data)); } } prev = it; it = pj_rbtree_next(&rb, it); } // Search. for (j=0; j MAX_COUNT) break; } pj_pool_release(pool); return err; } int rbtree_test() { return test(); } #endif /* INCLUDE_RBTREE_TEST */