|
WizardsToolkit
1.0.7
|
00001 /* 00002 Copyright 1999-2011 ImageMagick Studio LLC, a non-profit organization 00003 dedicated to making software imaging solutions freely available. 00004 00005 You may not use this file except in compliance with the License. 00006 obtain a copy of the License at 00007 00008 http://www.wizards-toolkit.org/script/license.php 00009 00010 Unless required by applicable law or agreed to in writing, software 00011 distributed under the License is distributed on an "AS IS" BASIS, 00012 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 00013 See the License for the specific language governing permissions and 00014 limitations under the License. 00015 00016 Wizard's Toolkit splay-tree methods. 00017 */ 00018 #ifndef _WIZARDSTOOLKIT_SPLAY_H 00019 #define _WIZARDSTOOLKIT_SPLAY_H 00020 00021 #if defined(__cplusplus) || defined(c_plusplus) 00022 extern "C" { 00023 #endif 00024 00025 typedef struct _SplayTreeInfo 00026 SplayTreeInfo; 00027 00028 extern WizardExport const void 00029 *GetNextKeyInSplayTree(SplayTreeInfo *), 00030 *GetNextValueInSplayTree(SplayTreeInfo *), 00031 *GetValueFromSplayTree(SplayTreeInfo *,const void *); 00032 00033 extern WizardExport int 00034 CompareSplayTreeString(const void *,const void *), 00035 CompareSplayTreeStringInfo(const void *,const void *); 00036 00037 extern WizardExport SplayTreeInfo 00038 *CloneSplayTree(SplayTreeInfo *,void *(*)(void *),void *(*)(void *)), 00039 *DestroySplayTree(SplayTreeInfo *), 00040 *NewSplayTree(int (*)(const void *,const void *),void *(*)(void *), 00041 void *(*)(void *)); 00042 00043 extern WizardExport size_t 00044 GetNumberOfNodesInSplayTree(const SplayTreeInfo *); 00045 00046 extern WizardExport void 00047 *RemoveNodeByValueFromSplayTree(SplayTreeInfo *,const void *), 00048 *RemoveNodeFromSplayTree(SplayTreeInfo *,const void *), 00049 ResetSplayTree(SplayTreeInfo *), 00050 ResetSplayTreeIterator(SplayTreeInfo *); 00051 00052 extern WizardExport WizardBooleanType 00053 AddValueToSplayTree(SplayTreeInfo *,const void *,const void *), 00054 DeleteNodeByValueFromSplayTree(SplayTreeInfo *,const void *), 00055 DeleteNodeFromSplayTree(SplayTreeInfo *,const void *); 00056 00057 #if defined(__cplusplus) || defined(c_plusplus) 00058 } 00059 #endif 00060 00061 #endif