00001 /************************************************************************** 00002 * 00003 * Copyright 2007 Tungsten Graphics, Inc., Cedar Park, Texas. 00004 * All Rights Reserved. 00005 * 00006 * Permission is hereby granted, free of charge, to any person obtaining a 00007 * copy of this software and associated documentation files (the 00008 * "Software"), to deal in the Software without restriction, including 00009 * without limitation the rights to use, copy, modify, merge, publish, 00010 * distribute, sub license, and/or sell copies of the Software, and to 00011 * permit persons to whom the Software is furnished to do so, subject to 00012 * the following conditions: 00013 * 00014 * The above copyright notice and this permission notice (including the 00015 * next paragraph) shall be included in all copies or substantial portions 00016 * of the Software. 00017 * 00018 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 00019 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 00020 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 00021 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR 00022 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 00023 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 00024 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 00025 * 00026 **************************************************************************/ 00027 00044 #ifndef CSO_HASH_H 00045 #define CSO_HASH_H 00046 00047 00048 #ifdef __cplusplus 00049 extern "C" { 00050 #endif 00051 00052 00053 struct cso_hash; 00054 struct cso_node; 00055 00056 00057 struct cso_hash_iter { 00058 struct cso_hash *hash; 00059 struct cso_node *node; 00060 }; 00061 00062 00063 struct cso_hash *cso_hash_create(void); 00064 void cso_hash_delete(struct cso_hash *hash); 00065 00066 00067 int cso_hash_size(struct cso_hash *hash); 00068 00069 00076 struct cso_hash_iter cso_hash_insert(struct cso_hash *hash, unsigned key, 00077 void *data); 00085 struct cso_hash_iter cso_hash_erase(struct cso_hash *hash, struct cso_hash_iter iter); 00086 00087 void *cso_hash_take(struct cso_hash *hash, unsigned key); 00088 00089 00090 00091 struct cso_hash_iter cso_hash_first_node(struct cso_hash *hash); 00092 00096 struct cso_hash_iter cso_hash_find(struct cso_hash *hash, unsigned key); 00097 00098 00099 int cso_hash_iter_is_null(struct cso_hash_iter iter); 00100 unsigned cso_hash_iter_key(struct cso_hash_iter iter); 00101 void *cso_hash_iter_data(struct cso_hash_iter iter); 00102 00103 00104 struct cso_hash_iter cso_hash_iter_next(struct cso_hash_iter iter); 00105 struct cso_hash_iter cso_hash_iter_prev(struct cso_hash_iter iter); 00106 00107 00113 void *cso_hash_find_data_from_template( struct cso_hash *hash, 00114 unsigned hash_key, 00115 void *templ, 00116 int size ); 00117 00118 00119 #ifdef __cplusplus 00120 } 00121 #endif 00122 00123 #endif