00001 /* 00002 * Copyright (c) 2005-2007 cielacanth <cielacanth AT s60.xrea.com> 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions 00007 * are met: 00008 * 1. Redistributions of source code must retain the above copyright 00009 * notice, this list of conditions and the following disclaimer. 00010 * 2. Redistributions in binary form must reproduce the above copyright 00011 * notice, this list of conditions and the following disclaimer in the 00012 * documentation and/or other materials provided with the distribution. 00013 * 00014 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 00015 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00016 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00017 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 00018 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 00019 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 00020 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 00021 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00022 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 00023 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 00024 * SUCH DAMAGE. 00025 */ 00026 00027 #ifndef __ALICEML_HASH__ 00028 #define __ALICEML_HASH__ 00029 00030 #include "aliceml.h" 00031 00032 #ifdef __cplusplus 00033 extern "C" { 00034 #endif 00035 00039 typedef struct ML_Hash ML_Hash; 00040 00044 typedef struct ML_HashPair { 00045 void *key; 00046 void *value; 00047 } ML_HashPair; 00048 00050 typedef ML_uint32 (ALICEMLCALL *ML_Hasher)(const void *key); 00051 00053 typedef int (ALICEMLCALL *ML_Callback_HashInsert)(ML_HashPair *pair); 00054 00056 typedef void (ALICEMLCALL *ML_Callback_HashRemove)(ML_HashPair *pair); 00057 00059 ALICEMLAPI ML_uint32 ALICEMLCALL ML_HashInteger(ML_uint32 value); 00060 00061 00063 ALICEMLAPI ML_Hash * ALICEMLCALL ML_Hash_Create(ML_Hasher hasher, 00064 ML_Comparator key_compare, 00065 ML_Callback_HashInsert insert, 00066 ML_Callback_HashRemove remove); 00067 00069 ALICEMLAPI void ALICEMLCALL ML_Hash_Destroy(ML_Hash *hash); 00070 00072 ALICEMLAPI ML_size ALICEMLCALL ML_Hash_GetSize(ML_Hash *hash); 00073 00075 ALICEMLAPI ML_size ALICEMLCALL ML_Hash_GetCapacity(ML_Hash *hash); 00076 00078 ALICEMLAPI ML_HashPair * ALICEMLCALL ML_Hash_Find(ML_Hash *hash, void *key); 00079 00081 ALICEMLAPI int ALICEMLCALL ML_Hash_Insert(ML_Hash *hash, void *key, void *value); 00082 00084 ALICEMLAPI int ALICEMLCALL ML_Hash_Erase(ML_Hash *hash, void *key); 00085 00087 ALICEMLAPI int ALICEMLCALL ML_Hash_Clear(ML_Hash *hash); 00088 00089 #ifdef __cplusplus 00090 } 00091 #endif 00092 00093 #endif
1.4.7