/* $Id$ */ /* * PJLIB - PJ Foundation Library * (C)2003-2005 Benny Prijono * * Author: * Benny Prijono * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #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 */