GRAYBYTE WORDPRESS FILE MANAGER3383

Server IP : 198.54.121.189 / Your IP : 216.73.216.112
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /opt/cpanel/ea-apr16/include/apr-1/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /opt/cpanel/ea-apr16/include/apr-1//apr_skiplist.h
/* Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You under the Apache License, Version 2.0
 * (the "License"); you may not use this file except in compliance with
 * the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef APR_SKIPLIST_H
#define APR_SKIPLIST_H
/**
 * @file apr_skiplist.h
 * @brief APR skip list implementation
 */

#include "apr.h"
#include "apr_portable.h"
#include <stdlib.h>

#ifdef __cplusplus
extern "C" {
#endif /* __cplusplus */

/**
 * @defgroup apr_skiplist Skip list implementation
 * Refer to http://en.wikipedia.org/wiki/Skip_list for information
 * about the purpose of and ideas behind skip lists.
 * @ingroup APR
 * @{
 */

/**
 * apr_skiplist_compare is the function type that must be implemented 
 * per object type that is used in a skip list for comparisons to maintain
 * order
 * */
typedef int (*apr_skiplist_compare) (void *, void *);

/**
 * apr_skiplist_freefunc is the function type that must be implemented
 * to handle elements as they are removed from a skip list.
 */
typedef void (*apr_skiplist_freefunc) (void *);

/** Opaque structure used to represent the skip list */
struct apr_skiplist;
/** Opaque structure used to represent the skip list */
typedef struct apr_skiplist apr_skiplist;

/** 
 * Opaque structure used to represent abstract nodes in the skip list
 * (an abstraction above the raw elements which are collected in the
 * skip list).
 */
struct apr_skiplistnode;
/** Opaque structure */
typedef struct apr_skiplistnode apr_skiplistnode;

/**
 * Allocate memory using the same mechanism as the skip list.
 * @param sl The skip list
 * @param size The amount to allocate
 * @remark If a pool was provided to apr_skiplist_init(), memory will
 * be allocated from the pool or from a free list maintained with
 * the skip list.  Otherwise, memory will be allocated using the
 * C standard library heap functions.
 */
APR_DECLARE(void *) apr_skiplist_alloc(apr_skiplist *sl, size_t size);

/**
 * Free memory using the same mechanism as the skip list.
 * @param sl The skip list
 * @param mem The object to free
 * @remark If a pool was provided to apr_skiplist_init(), memory will
 * be added to a free list maintained with the skip list and be available
 * to operations on the skip list or to other calls to apr_skiplist_alloc().
 * Otherwise, memory will be freed using the  C standard library heap
 * functions.
 */
APR_DECLARE(void) apr_skiplist_free(apr_skiplist *sl, void *mem);

/**
 * Allocate a new skip list
 * @param sl The pointer in which to return the newly created skip list
 * @param p The pool from which to allocate the skip list (optional).
 * @remark Unlike most APR functions, a pool is optional.  If no pool
 * is provided, the C standard library heap functions will be used instead.
 */
APR_DECLARE(apr_status_t) apr_skiplist_init(apr_skiplist **sl, apr_pool_t *p);

/**
 * Set the comparison functions to be used for searching the skip list.
 * @param sl The skip list
 * @param XXX1 FIXME
 * @param XXX2 FIXME
 *
 * @remark If existing comparison functions are being replaced, the index
 * will be replaced during this call.  That is a potentially expensive
 * operation.
 */
APR_DECLARE(void) apr_skiplist_set_compare(apr_skiplist *sl, apr_skiplist_compare XXX1,
                             apr_skiplist_compare XXX2);

/**
 * Set the indexing functions to the specified comparison functions and
 * rebuild the index.
 * @param sl The skip list
 * @param XXX1 FIXME
 * @param XXX2 FIXME
 *
 * @remark If an index already exists, it will not be replaced and the
 * comparison functions will not be changed.
 */
APR_DECLARE(void) apr_skiplist_add_index(apr_skiplist *sl, apr_skiplist_compare XXX1,
                        apr_skiplist_compare XXX2);

/**
 * Return the list maintained by the skip list abstraction.
 * @param sl The skip list
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_getlist(apr_skiplist *sl);

/**
 * Return the next matching element in the skip list using the specified
 * comparison function.
 * @param sl The skip list
 * @param data The value to search for
 * @param iter A pointer to the returned skip list node representing the element
 * found
 * @param func The comparison function to use
 */
APR_DECLARE(void *) apr_skiplist_find_compare(apr_skiplist *sl,
                               void *data,
                               apr_skiplistnode **iter,
                               apr_skiplist_compare func);

/**
 * Return the next matching element in the skip list using the current comparison
 * function.
 * @param sl The skip list
 * @param data The value to search for
 * @param iter A pointer to the returned skip list node representing the element
 * found
 */
APR_DECLARE(void *) apr_skiplist_find(apr_skiplist *sl, void *data, apr_skiplistnode **iter);

/**
 * Return the last matching element in the skip list using the specified
 * comparison function.
 * @param sl The skip list
 * @param data The value to search for
 * @param iter A pointer to the returned skip list node representing the element
 * found
 * @param comp The comparison function to use
 */
APR_DECLARE(void *) apr_skiplist_last_compare(apr_skiplist *sl, void *data,
                                              apr_skiplistnode **iter,
                                              apr_skiplist_compare comp);

/**
 * Return the last matching element in the skip list using the current comparison
 * function.
 * @param sl The skip list
 * @param data The value to search for
 * @param iter A pointer to the returned skip list node representing the element
 * found
 */
APR_DECLARE(void *) apr_skiplist_last(apr_skiplist *sl, void *data,
                                      apr_skiplistnode **iter);

/**
 * Return the next element in the skip list.
 * @param sl The skip list
 * @param iter On entry, a pointer to the skip list node to start with; on return,
 * a pointer to the skip list node representing the element returned
 * @remark If iter points to a NULL value on entry, NULL will be returned.
 */
APR_DECLARE(void *) apr_skiplist_next(apr_skiplist *sl, apr_skiplistnode **iter);

/**
 * Return the previous element in the skip list.
 * @param sl The skip list
 * @param iter On entry, a pointer to the skip list node to start with; on return,
 * a pointer to the skip list node representing the element returned
 * @remark If iter points to a NULL value on entry, NULL will be returned.
 */
APR_DECLARE(void *) apr_skiplist_previous(apr_skiplist *sl, apr_skiplistnode **iter);

/**
 * Return the element of the skip list node
 * @param iter The skip list node
 */
APR_DECLARE(void *) apr_skiplist_element(apr_skiplistnode *iter);

/**
 * Insert an element into the skip list using the specified comparison function
 * if it does not already exist.
 * @param sl The skip list
 * @param data The element to insert
 * @param comp The comparison function to use for placement into the skip list
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_insert_compare(apr_skiplist *sl,
                                          void *data, apr_skiplist_compare comp);

/**
 * Insert an element into the skip list using the existing comparison function
 * if it does not already exist.
 * @param sl The skip list
 * @param data The element to insert
 * @remark If no comparison function has been set for the skip list, the element
 * will not be inserted and NULL will be returned.
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_insert(apr_skiplist* sl, void *data);

/**
 * Add an element into the skip list using the specified comparison function
 * allowing for duplicates.
 * @param sl The skip list
 * @param data The element to add
 * @param comp The comparison function to use for placement into the skip list
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_add_compare(apr_skiplist *sl,
                                          void *data, apr_skiplist_compare comp);

/**
 * Add an element into the skip list using the existing comparison function
 * allowing for duplicates.
 * @param sl The skip list
 * @param data The element to insert
 * @remark If no comparison function has been set for the skip list, the element
 * will not be inserted and NULL will be returned.
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_add(apr_skiplist* sl, void *data);

/**
 * Add an element into the skip list using the specified comparison function
 * removing the existing duplicates.
 * @param sl The skip list
 * @param data The element to insert
 * @param comp The comparison function to use for placement into the skip list
 * @param myfree A function to be called for each removed duplicate
 * @remark If no comparison function has been set for the skip list, the element
 * will not be inserted, none will be replaced, and NULL will be returned.
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_replace_compare(apr_skiplist *sl,
                                    void *data, apr_skiplist_freefunc myfree,
                                    apr_skiplist_compare comp);

/**
 * Add an element into the skip list using the existing comparison function
 * removing the existing duplicates.
 * @param sl The skip list
 * @param data The element to insert
 * @param myfree A function to be called for each removed duplicate
 * @remark If no comparison function has been set for the skip list, the element
 * will not be inserted, none will be replaced, and NULL will be returned.
 */
APR_DECLARE(apr_skiplistnode *) apr_skiplist_replace(apr_skiplist *sl,
                                    void *data, apr_skiplist_freefunc myfree);

/**
 * Remove a node from the skip list.
 * @param sl The skip list
 * @param iter The skip list node to remove
 * @param myfree A function to be called for the removed element
 */
APR_DECLARE(int) apr_skiplist_remove_node(apr_skiplist *sl,
                                          apr_skiplistnode *iter,
                                          apr_skiplist_freefunc myfree);

/**
 * Remove an element from the skip list using the specified comparison function for
 * locating the element. In the case of duplicates, the 1st entry will be removed.
 * @param sl The skip list
 * @param data The element to remove
 * @param myfree A function to be called for each removed element
 * @param comp The comparison function to use for placement into the skip list
 * @remark If the element is not found, 0 will be returned.  Otherwise, the heightXXX
 * will be returned.
 */
APR_DECLARE(int) apr_skiplist_remove_compare(apr_skiplist *sl, void *data,
                               apr_skiplist_freefunc myfree, apr_skiplist_compare comp);

/**
 * Remove an element from the skip list using the existing comparison function for
 * locating the element. In the case of duplicates, the 1st entry will be removed.
 * @param sl The skip list
 * @param data The element to remove
 * @param myfree A function to be called for each removed element
 * @remark If the element is not found, 0 will be returned.  Otherwise, the heightXXX
 * will be returned.
 * @remark If no comparison function has been set for the skip list, the element
 * will not be removed and 0 will be returned.
 */
APR_DECLARE(int) apr_skiplist_remove(apr_skiplist *sl, void *data, apr_skiplist_freefunc myfree);

/**
 * Remove all elements from the skip list.
 * @param sl The skip list
 * @param myfree A function to be called for each removed element
 */
APR_DECLARE(void) apr_skiplist_remove_all(apr_skiplist *sl, apr_skiplist_freefunc myfree);

/**
 * Remove each element from the skip list.
 * @param sl The skip list
 * @param myfree A function to be called for each removed element
 */
APR_DECLARE(void) apr_skiplist_destroy(apr_skiplist *sl, apr_skiplist_freefunc myfree);

/**
 * Return the first element in the skip list, removing the element from the skip list.
 * @param sl The skip list
 * @param myfree A function to be called for the removed element
 * @remark NULL will be returned if there are no elements
 */
APR_DECLARE(void *) apr_skiplist_pop(apr_skiplist *sl, apr_skiplist_freefunc myfree);

/**
 * Return the first element in the skip list, leaving the element in the skip list.
 * @param sl The skip list
 * @remark NULL will be returned if there are no elements
 */
APR_DECLARE(void *) apr_skiplist_peek(apr_skiplist *sl);

/**
 * Return the size of the list (number of elements), in O(1).
 * @param sl The skip list
 */
APR_DECLARE(size_t) apr_skiplist_size(const apr_skiplist *sl);

/**
 * Return the height of the list (number of skip paths), in O(1).
 * @param sl The skip list
 */
APR_DECLARE(int) apr_skiplist_height(const apr_skiplist *sl);

/**
 * Return the predefined maximum height of the skip list.
 * @param sl The skip list
 */
APR_DECLARE(int) apr_skiplist_preheight(const apr_skiplist *sl);

/**
 * Set a predefined maximum height for the skip list.
 * @param sl The skip list
 * @param to The preheight to set, or a nul/negative value to disable.
 * @remark When a preheight is used, the height of each inserted element is
 * computed randomly up to this preheight instead of the current skip list's
 * height plus one used by the default implementation. Using a preheight can
 * probably ensure more fairness with long living elements (since with an
 * adaptative height, former elements may have been created with a low height,
 * hence a longest path to reach them while the skip list grows). On the other
 * hand, the default behaviour (preheight <= 0) with a growing and decreasing
 * maximum height is more adaptative/suitable for short living values.
 * @note Should be called before any insertion/add.
 */
APR_DECLARE(void) apr_skiplist_set_preheight(apr_skiplist *sl, int to);

/**
 * Merge two skip lists.  XXX SEMANTICS
 * @param sl1 One of two skip lists to be merged
 * @param sl2 The other of two skip lists to be merged
 */
APR_DECLARE(apr_skiplist *) apr_skiplist_merge(apr_skiplist *sl1, apr_skiplist *sl2);

/** @} */

#ifdef __cplusplus
}
#endif

#endif /* ! APR_SKIPLIST_H */

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
May 22 2025 09:10:35
root / root
0755
apr-x86_64.h
17.909 KB
May 22 2025 09:10:35
root / root
0644
apr.h
0.621 KB
May 22 2025 09:10:36
root / root
0644
apr_allocator.h
6.071 KB
May 22 2025 09:10:35
root / root
0644
apr_anylock.h
4.932 KB
September 27 2023 15:55:48
root / root
0644
apr_atomic.h
6.043 KB
May 22 2025 09:10:35
root / root
0644
apr_base64.h
3.754 KB
September 27 2023 15:55:48
root / root
0644
apr_buckets.h
63.146 KB
September 27 2023 15:55:48
root / root
0644
apr_crypto.h
19.685 KB
September 27 2023 15:55:48
root / root
0644
apr_cstr.h
11.131 KB
May 22 2025 09:10:35
root / root
0644
apr_date.h
3.471 KB
September 27 2023 15:55:48
root / root
0644
apr_dbd.h
23.349 KB
September 27 2023 15:55:48
root / root
0644
apr_dbm.h
8.397 KB
September 27 2023 15:55:48
root / root
0644
apr_dso.h
2.637 KB
May 22 2025 09:10:35
root / root
0644
apr_encode.h
30.349 KB
May 22 2025 09:10:35
root / root
0644
apr_env.h
2.056 KB
May 22 2025 09:10:35
root / root
0644
apr_errno.h
53.771 KB
May 22 2025 09:10:35
root / root
0644
apr_escape.h
17.232 KB
May 22 2025 09:10:35
root / root
0644
apr_file_info.h
17.172 KB
May 22 2025 09:10:35
root / root
0644
apr_file_io.h
42.881 KB
May 22 2025 09:10:35
root / root
0644
apr_fnmatch.h
6.083 KB
May 22 2025 09:10:35
root / root
0644
apr_general.h
7.337 KB
May 22 2025 09:10:35
root / root
0644
apr_getopt.h
5.84 KB
May 22 2025 09:10:35
root / root
0644
apr_global_mutex.h
7.188 KB
May 22 2025 09:10:35
root / root
0644
apr_hash.h
10.08 KB
May 22 2025 09:10:35
root / root
0644
apr_hooks.h
12.363 KB
September 27 2023 15:55:48
root / root
0644
apr_inherit.h
2.089 KB
May 22 2025 09:10:35
root / root
0644
apr_ldap.h
5.57 KB
September 27 2023 15:55:48
root / root
0644
apr_ldap_init.h
5.645 KB
September 27 2023 15:55:48
root / root
0644
apr_ldap_option.h
8.402 KB
September 27 2023 15:55:48
root / root
0644
apr_ldap_rebind.h
3.094 KB
September 27 2023 15:55:48
root / root
0644
apr_ldap_url.h
3.71 KB
September 27 2023 15:55:48
root / root
0644
apr_lib.h
8.232 KB
May 22 2025 09:10:35
root / root
0644
apr_md4.h
4.419 KB
September 27 2023 15:55:48
root / root
0644
apr_md5.h
6.201 KB
September 27 2023 15:55:48
root / root
0644
apr_memcache.h
16.82 KB
September 27 2023 15:55:48
root / root
0644
apr_mmap.h
5.013 KB
May 22 2025 09:10:35
root / root
0644
apr_network_io.h
36.017 KB
May 22 2025 09:10:35
root / root
0644
apr_optional.h
2.715 KB
September 27 2023 15:55:48
root / root
0644
apr_optional_hooks.h
3.781 KB
September 27 2023 15:55:48
root / root
0644
apr_perms_set.h
1.864 KB
May 22 2025 09:10:35
root / root
0644
apr_poll.h
20.604 KB
May 22 2025 09:10:35
root / root
0644
apr_pools.h
30.938 KB
May 22 2025 09:10:35
root / root
0644
apr_portable.h
20.022 KB
May 22 2025 09:10:35
root / root
0644
apr_proc_mutex.h
6.848 KB
May 22 2025 09:10:35
root / root
0644
apr_queue.h
3.984 KB
September 27 2023 15:55:48
root / root
0644
apr_random.h
4.918 KB
May 22 2025 09:10:35
root / root
0644
apr_redis.h
15.62 KB
September 27 2023 15:55:48
root / root
0644
apr_reslist.h
7.008 KB
September 27 2023 15:55:48
root / root
0644
apr_ring.h
18.775 KB
May 22 2025 09:10:35
root / root
0644
apr_rmm.h
4.666 KB
September 27 2023 15:55:48
root / root
0644
apr_sdbm.h
5.97 KB
September 27 2023 15:55:48
root / root
0644
apr_sha1.h
3.793 KB
September 27 2023 15:55:48
root / root
0644
apr_shm.h
9.261 KB
May 22 2025 09:10:35
root / root
0644
apr_signal.h
2.696 KB
May 22 2025 09:10:35
root / root
0644
apr_siphash.h
6.014 KB
September 27 2023 15:55:48
root / root
0644
apr_skiplist.h
14.192 KB
May 22 2025 09:10:35
root / root
0644
apr_strings.h
14.548 KB
May 22 2025 09:10:35
root / root
0644
apr_strmatch.h
2.614 KB
September 27 2023 15:55:48
root / root
0644
apr_support.h
1.596 KB
May 22 2025 09:10:35
root / root
0644
apr_tables.h
18.9 KB
May 22 2025 09:10:35
root / root
0644
apr_thread_cond.h
5.396 KB
May 22 2025 09:10:35
root / root
0644
apr_thread_mutex.h
4.393 KB
May 22 2025 09:10:35
root / root
0644
apr_thread_pool.h
10.844 KB
September 27 2023 15:55:48
root / root
0644
apr_thread_proc.h
36.805 KB
May 22 2025 09:10:35
root / root
0644
apr_thread_rwlock.h
4.654 KB
May 22 2025 09:10:35
root / root
0644
apr_time.h
7.386 KB
May 22 2025 09:10:35
root / root
0644
apr_uri.h
6.435 KB
September 27 2023 15:55:48
root / root
0644
apr_user.h
5.186 KB
May 22 2025 09:10:35
root / root
0644
apr_uuid.h
2.053 KB
September 27 2023 15:55:48
root / root
0644
apr_version.h
5.218 KB
May 22 2025 09:10:35
root / root
0644
apr_want.h
2.889 KB
May 22 2025 09:10:35
root / root
0644
apr_xlate.h
6.258 KB
September 27 2023 15:55:48
root / root
0644
apr_xml.h
12.193 KB
September 27 2023 15:55:48
root / root
0644
apu.h
4.217 KB
September 27 2023 15:55:48
root / root
0644
apu_errno.h
5.316 KB
September 27 2023 15:55:48
root / root
0644
apu_version.h
4.199 KB
September 27 2023 15:55:48
root / root
0644
apu_want.h
1.448 KB
September 27 2023 15:55:48
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF