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

📄 apr_tables.h

📁 apache的软件linux版本
💻 H
📖 第 1 页 / 共 2 页
字号:
/* 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_TABLES_H#define APR_TABLES_H/** * @file apr_tables.h * @brief APR Table library */#include "apr.h"#include "apr_pools.h"#if APR_HAVE_STDARG_H#include <stdarg.h>     /* for va_list */#endif#ifdef __cplusplusextern "C" {#endif /* __cplusplus *//** * @defgroup apr_tables Table and Array Functions * @ingroup APR  * Tables are used to store entirely opaque structures  * for applications, while Arrays are usually used to * deal with string lists. * @{ *//** the table abstract data type */typedef struct apr_table_t apr_table_t;/** @see apr_array_header_t */typedef struct apr_array_header_t apr_array_header_t;/** An opaque array type */struct apr_array_header_t {    /** The pool the array is allocated out of */    apr_pool_t *pool;    /** The amount of memory allocated for each element of the array */    int elt_size;    /** The number of active elements in the array */    int nelts;    /** The number of elements allocated in the array */    int nalloc;    /** The elements in the array */    char *elts;};/** * The (opaque) structure for string-content tables. */typedef struct apr_table_entry_t apr_table_entry_t;/** The type for each entry in a string-content table */struct apr_table_entry_t {    /** The key for the current table entry */    char *key;          /* maybe NULL in future;                         * check when iterating thru table_elts                         */    /** The value for the current table entry */    char *val;    /** A checksum for the key, for use by the apr_table internals */    apr_uint32_t key_checksum;};/** * Get the elements from a table * @param t The table * @return An array containing the contents of the table */APR_DECLARE(const apr_array_header_t *) apr_table_elts(const apr_table_t *t);/** * Determine if the table is empty * @param t The table to check * @return True if empty, False otherwise */APR_DECLARE(int) apr_is_empty_table(const apr_table_t *t);/** * Determine if the array is empty * @param a The array to check * @return True if empty, False otherwise */APR_DECLARE(int) apr_is_empty_array(const apr_array_header_t *a);/** * Create an array * @param p The pool to allocate the memory out of * @param nelts the number of elements in the initial array * @param elt_size The size of each element in the array. * @return The new array */APR_DECLARE(apr_array_header_t *) apr_array_make(apr_pool_t *p,                                                 int nelts, int elt_size);/** * Add a new element to an array * @param arr The array to add an element to. * @return Location for the new element in the array. * @remark If there are no free spots in the array, then this function will *         allocate new space for the new element. */APR_DECLARE(void *) apr_array_push(apr_array_header_t *arr);/** * Remove an element from an array * @param arr The array to remove an element from. * @return Location of the element in the array. * @remark If there are no elements in the array, NULL is returned. */APR_DECLARE(void *) apr_array_pop(apr_array_header_t *arr);/** * Concatenate two arrays together * @param dst The destination array, and the one to go first in the combined  *            array * @param src The source array to add to the destination array */APR_DECLARE(void) apr_array_cat(apr_array_header_t *dst,			        const apr_array_header_t *src);/** * Copy the entire array * @param p The pool to allocate the copy of the array out of * @param arr The array to copy * @return An exact copy of the array passed in * @remark The alternate apr_array_copy_hdr copies only the header, and arranges  *         for the elements to be copied if (and only if) the code subsequently *         does a push or arraycat. */APR_DECLARE(apr_array_header_t *) apr_array_copy(apr_pool_t *p,                                      const apr_array_header_t *arr);/** * Copy the headers of the array, and arrange for the elements to be copied if * and only if the code subsequently does a push or arraycat. * @param p The pool to allocate the copy of the array out of * @param arr The array to copy * @return An exact copy of the array passed in * @remark The alternate apr_array_copy copies the *entire* array. */APR_DECLARE(apr_array_header_t *) apr_array_copy_hdr(apr_pool_t *p,                                      const apr_array_header_t *arr);/** * Append one array to the end of another, creating a new array in the process. * @param p The pool to allocate the new array out of * @param first The array to put first in the new array. * @param second The array to put second in the new array. * @return A new array containing the data from the two arrays passed in.*/APR_DECLARE(apr_array_header_t *) apr_array_append(apr_pool_t *p,                                      const apr_array_header_t *first,                                      const apr_array_header_t *second);/** * Generates a new string from the apr_pool_t containing the concatenated  * sequence of substrings referenced as elements within the array.  The string  * will be empty if all substrings are empty or null, or if there are no  * elements in the array.  If sep is non-NUL, it will be inserted between  * elements as a separator. * @param p The pool to allocate the string out of * @param arr The array to generate the string from * @param sep The separator to use * @return A string containing all of the data in the array. */APR_DECLARE(char *) apr_array_pstrcat(apr_pool_t *p,				      const apr_array_header_t *arr,				      const char sep);/** * Make a new table * @param p The pool to allocate the pool out of * @param nelts The number of elements in the initial table. * @return The new table. * @warning This table can only store text data */APR_DECLARE(apr_table_t *) apr_table_make(apr_pool_t *p, int nelts);/** * Create a new table and copy another table into it * @param p The pool to allocate the new table out of * @param t The table to copy * @return A copy of the table passed in */APR_DECLARE(apr_table_t *) apr_table_copy(apr_pool_t *p,                                          const apr_table_t *t);/** * Delete all of the elements from a table * @param t The table to clear */APR_DECLARE(void) apr_table_clear(apr_table_t *t);/**

⌨️ 快捷键说明

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