/* $Id$ */ /* * Copyright (C) 2008-2011 Teluu Inc. (http://www.teluu.com) * Copyright (C) 2003-2008 Benny Prijono * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; 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 */