⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rumavl.h

📁 CRFsuite is a very fast implmentation of the Conditional Random Fields (CRF) algorithm. It handles t
💻 H
字号:
/* * RumAVL - Threaded AVL Tree Implementation * * Copyright (c) 2005-2007 Jesse Long <jpl@unknown.za.net> * All rights reserved. *  * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * *   1. The above copyright notice and this permission notice shall be *	included in all copies or substantial portions of the Software. *   2. The origin of the Software must not be misrepresented; you must not *	claim that you wrote the original Software. *   3. Altered source versions of the Software must be plainly marked as *	such, and must not be misrepresented as being the original Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. *//* * Please see the `README' file, the documentation in the `doc' directory and * the `rumavl.c' source file for more information. */#ifndef RUMAVL_H#define RUMAVL_H 1#ifdef __cplusplusextern "C" {#endif#include <stddef.h>	/* size_t */    /*---------------------------------------------------------------------------- * DATA TYPES *--------------------------------------------------------------------------*//* Opaque context handle for the tree */typedef struct rumavl RUMAVL;/* Node type - used for iterating */typedef struct rumavl_node RUMAVL_NODE;/*---------------------------------------------------------------------------- * FUNDEMENTAL FUNCTIONS *--------------------------------------------------------------------------*//* Create a new RumAVL tree */RUMAVL *rumavl_new (size_t reclen, 		    int (*cmp)(const void *, const void *, size_t, void *),		    void *(*alloc)(void *, size_t, void *),		    void *udata);/* Destroy a RumAVL tree */void rumavl_destroy (RUMAVL *tree);/* This function returns the size of each record in a tree */size_t rumavl_record_size (RUMAVL *tree);/* Get a pointer to the udata pointer */void **rumavl_udata  (RUMAVL *tree);/* Insert a record into a tree, overwriting an existing record necessary */int rumavl_set (RUMAVL *tree, const void *record);/* Insert a record into a tree, never overwrites an existing record */int rumavl_insert (RUMAVL *tree, const void *record);/* Retrieve record from tree, or NULL */void *rumavl_find (RUMAVL *tree, const void *find);/* Remove record from tree */int rumavl_delete (RUMAVL *tree, const void *record);/*---------------------------------------------------------------------------- * ITERATOR FUNCTIONS *--------------------------------------------------------------------------*//* Get a pointer to the node containing a specific record */RUMAVL_NODE *rumavl_node_find (RUMAVL *tree, const void *find, void **record);/* Get the next node in sequence after a specific node, in a specific * direction, or get the first node on either end of a tree */RUMAVL_NODE *rumavl_node_next (RUMAVL *tree, RUMAVL_NODE *node, int dir,				    void **record);/* Possible directions */#define RUMAVL_DESC (-1)#define RUMAVL_ASC  (+1)/* Get a record held by a specific node */void *rumavl_node_record (RUMAVL_NODE *node);/* Pass each record in a tree to a user defined callback function */extern int rumavl_foreach (RUMAVL *tree, int dir,	    int (*cbfn)(RUMAVL *, void *, void *), void *udata);/*---------------------------------------------------------------------------- * CALLBACK FUNCTIONS * * Functions giving you more control over the actions of this library. *--------------------------------------------------------------------------*/int (**rumavl_owcb(RUMAVL *tree))(RUMAVL *, RUMAVL_NODE *, void *, 	const void *, void *);int (**rumavl_delcb(RUMAVL *tree))(RUMAVL *, RUMAVL_NODE *, void *, void *);/*---------------------------------------------------------------------------- * MEMORY MANAGEMENT * * The rumavl_mem struct is used to define how a RUMAVL object allocates * and frees memory. *--------------------------------------------------------------------------*/void *(**rumavl_alloc(RUMAVL *tree))(void *ptr, size_t size, void *udata);/*---------------------------------------------------------------------------- * ERROR CODES * * The functions returning int's will return these errors *--------------------------------------------------------------------------*/#define RUMAVL_ERR_INVAL  (-1)	/* Invalid argument */#define RUMAVL_ERR_NOMEM  (-2)	/* Insufficient memory */#define RUMAVL_ERR_NOENT  (-3)	/* Entry does not exist */#define RUMAVL_ERR_EORNG  (-5)	/* No nodes left in range */#define RUMAVL_ERR_EXIST  (-6)	/* Entry already exists *//* returns static string describing error number */extern const char *rumavl_strerror (int errno);#ifdef __cplusplus}#endif#endif /* ifndef RUMAVL_H */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -