SILENT KILLERPanel

Current Path: > > opt > cpanel > ea-apr16 > > include > apr-1


Operation   : Linux premium131.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
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/cpanel/ea-apr16//include/apr-1

NameTypeSizeLast ModifiedActions
apr-x86_64.h File 18339 bytes May 22 2025 09:10:35.
apr.h File 636 bytes May 22 2025 09:10:36.
apr_allocator.h File 6217 bytes May 22 2025 09:10:35.
apr_anylock.h File 5050 bytes September 27 2023 15:55:48.
apr_atomic.h File 6188 bytes May 22 2025 09:10:35.
apr_base64.h File 3844 bytes September 27 2023 15:55:48.
apr_buckets.h File 64661 bytes September 27 2023 15:55:48.
apr_crypto.h File 20157 bytes September 27 2023 15:55:48.
apr_cstr.h File 11398 bytes May 22 2025 09:10:35.
apr_date.h File 3554 bytes September 27 2023 15:55:48.
apr_dbd.h File 23909 bytes September 27 2023 15:55:48.
apr_dbm.h File 8599 bytes September 27 2023 15:55:48.
apr_dso.h File 2700 bytes May 22 2025 09:10:35.
apr_encode.h File 31077 bytes May 22 2025 09:10:35.
apr_env.h File 2105 bytes May 22 2025 09:10:35.
apr_errno.h File 55061 bytes May 22 2025 09:10:35.
apr_escape.h File 17646 bytes May 22 2025 09:10:35.
apr_file_info.h File 17584 bytes May 22 2025 09:10:35.
apr_file_io.h File 43910 bytes May 22 2025 09:10:35.
apr_fnmatch.h File 6229 bytes May 22 2025 09:10:35.
apr_general.h File 7513 bytes May 22 2025 09:10:35.
apr_getopt.h File 5980 bytes May 22 2025 09:10:35.
apr_global_mutex.h File 7361 bytes May 22 2025 09:10:35.
apr_hash.h File 10322 bytes May 22 2025 09:10:35.
apr_hooks.h File 12660 bytes September 27 2023 15:55:48.
apr_inherit.h File 2139 bytes May 22 2025 09:10:35.
apr_ldap.h File 5704 bytes September 27 2023 15:55:48.
apr_ldap_init.h File 5780 bytes September 27 2023 15:55:48.
apr_ldap_option.h File 8604 bytes September 27 2023 15:55:48.
apr_ldap_rebind.h File 3168 bytes September 27 2023 15:55:48.
apr_ldap_url.h File 3799 bytes September 27 2023 15:55:48.
apr_lib.h File 8430 bytes May 22 2025 09:10:35.
apr_md4.h File 4525 bytes September 27 2023 15:55:48.
apr_md5.h File 6350 bytes September 27 2023 15:55:48.
apr_memcache.h File 17224 bytes September 27 2023 15:55:48.
apr_mmap.h File 5133 bytes May 22 2025 09:10:35.
apr_network_io.h File 36881 bytes May 22 2025 09:10:35.
apr_optional.h File 2780 bytes September 27 2023 15:55:48.
apr_optional_hooks.h File 3872 bytes September 27 2023 15:55:48.
apr_perms_set.h File 1909 bytes May 22 2025 09:10:35.
apr_poll.h File 21099 bytes May 22 2025 09:10:35.
apr_pools.h File 31680 bytes May 22 2025 09:10:35.
apr_portable.h File 20503 bytes May 22 2025 09:10:35.
apr_proc_mutex.h File 7012 bytes May 22 2025 09:10:35.
apr_queue.h File 4080 bytes September 27 2023 15:55:48.
apr_random.h File 5036 bytes May 22 2025 09:10:35.
apr_redis.h File 15995 bytes September 27 2023 15:55:48.
apr_reslist.h File 7176 bytes September 27 2023 15:55:48.
apr_ring.h File 19226 bytes May 22 2025 09:10:35.
apr_rmm.h File 4778 bytes September 27 2023 15:55:48.
apr_sdbm.h File 6113 bytes September 27 2023 15:55:48.
apr_sha1.h File 3884 bytes September 27 2023 15:55:48.
apr_shm.h File 9483 bytes May 22 2025 09:10:35.
apr_signal.h File 2761 bytes May 22 2025 09:10:35.
apr_siphash.h File 6158 bytes September 27 2023 15:55:48.
apr_skiplist.h File 14533 bytes May 22 2025 09:10:35.
apr_strings.h File 14897 bytes May 22 2025 09:10:35.
apr_strmatch.h File 2677 bytes September 27 2023 15:55:48.
apr_support.h File 1634 bytes May 22 2025 09:10:35.
apr_tables.h File 19354 bytes May 22 2025 09:10:35.
apr_thread_cond.h File 5525 bytes May 22 2025 09:10:35.
apr_thread_mutex.h File 4498 bytes May 22 2025 09:10:35.
apr_thread_pool.h File 11104 bytes September 27 2023 15:55:48.
apr_thread_proc.h File 37688 bytes May 22 2025 09:10:35.
apr_thread_rwlock.h File 4766 bytes May 22 2025 09:10:35.
apr_time.h File 7563 bytes May 22 2025 09:10:35.
apr_uri.h File 6589 bytes September 27 2023 15:55:48.
apr_user.h File 5310 bytes May 22 2025 09:10:35.
apr_uuid.h File 2102 bytes September 27 2023 15:55:48.
apr_version.h File 5343 bytes May 22 2025 09:10:35.
apr_want.h File 2958 bytes May 22 2025 09:10:35.
apr_xlate.h File 6408 bytes September 27 2023 15:55:48.
apr_xml.h File 12486 bytes September 27 2023 15:55:48.
apu.h File 4318 bytes September 27 2023 15:55:48.
apu_errno.h File 5444 bytes September 27 2023 15:55:48.
apu_version.h File 4300 bytes September 27 2023 15:55:48.
apu_want.h File 1483 bytes September 27 2023 15:55:48.

Reading File: //opt/cpanel/ea-apr16//include/apr-1/apr_allocator.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_ALLOCATOR_H
#define APR_ALLOCATOR_H

/**
 * @file apr_allocator.h
 * @brief APR Internal Memory Allocation
 */

#include "apr.h"
#include "apr_errno.h"
#define APR_WANT_MEMFUNC /**< For no good reason? */
#include "apr_want.h"

#ifdef __cplusplus
extern "C" {
#endif

/**
 * @defgroup apr_allocator Internal Memory Allocation
 * @ingroup APR 
 * @{
 */

/** the allocator structure */
typedef struct apr_allocator_t apr_allocator_t;
/** the structure which holds information about the allocation */
typedef struct apr_memnode_t apr_memnode_t;

/** basic memory node structure
 * @note The next, ref and first_avail fields are available for use by the
 *       caller of apr_allocator_alloc(), the remaining fields are read-only.
 *       The next field has to be used with caution and sensibly set when the
 *       memnode is passed back to apr_allocator_free().  See apr_allocator_free()
 *       for details.  
 *       The ref and first_avail fields will be properly restored by
 *       apr_allocator_free().
 */
struct apr_memnode_t {
    apr_memnode_t *next;            /**< next memnode */
    apr_memnode_t **ref;            /**< reference to self */
    apr_uint32_t   index;           /**< size */
    apr_uint32_t   free_index;      /**< how much free */
    char          *first_avail;     /**< pointer to first free memory */
    char          *endp;            /**< pointer to end of free memory */
};

/** The base size of a memory node - aligned.  */
#define APR_MEMNODE_T_SIZE APR_ALIGN_DEFAULT(sizeof(apr_memnode_t))

/** Symbolic constants */
#define APR_ALLOCATOR_MAX_FREE_UNLIMITED 0

/**
 * Create a new allocator
 * @param allocator The allocator we have just created.
 *
 */
APR_DECLARE(apr_status_t) apr_allocator_create(apr_allocator_t **allocator)
                          __attribute__((nonnull(1)));

/**
 * Destroy an allocator
 * @param allocator The allocator to be destroyed
 * @remark Any memnodes not given back to the allocator prior to destroying
 *         will _not_ be free()d.
 */
APR_DECLARE(void) apr_allocator_destroy(apr_allocator_t *allocator)
                  __attribute__((nonnull(1)));

/**
 * Allocate a block of mem from the allocator
 * @param allocator The allocator to allocate from
 * @param size The size of the mem to allocate (excluding the
 *        memnode structure)
 */
APR_DECLARE(apr_memnode_t *) apr_allocator_alloc(apr_allocator_t *allocator,
                                                 apr_size_t size)
                             __attribute__((nonnull(1)));

/**
 * Free a list of blocks of mem, giving them back to the allocator.
 * The list is typically terminated by a memnode with its next field
 * set to NULL.
 * @param allocator The allocator to give the mem back to
 * @param memnode The memory node to return
 */
APR_DECLARE(void) apr_allocator_free(apr_allocator_t *allocator,
                                     apr_memnode_t *memnode)
                  __attribute__((nonnull(1,2)));
 
/**
 * Get the true size that would be allocated for the given size (including
 * the header and alignment).
 * @param allocator The allocator from which to the memory would be allocated
 * @param size The size to align
 * @return The aligned size (or zero on apr_size_t overflow)
 */
APR_DECLARE(apr_size_t) apr_allocator_align(apr_allocator_t *allocator,
                                            apr_size_t size);

#include "apr_pools.h"

/**
 * Set the owner of the allocator
 * @param allocator The allocator to set the owner for
 * @param pool The pool that is to own the allocator
 * @remark Typically pool is the highest level pool using the allocator
 */
/*
 * XXX: see if we can come up with something a bit better.  Currently
 * you can make a pool an owner, but if the pool doesn't use the allocator
 * the allocator will never be destroyed.
 */
APR_DECLARE(void) apr_allocator_owner_set(apr_allocator_t *allocator,
                                          apr_pool_t *pool)
                  __attribute__((nonnull(1)));

/**
 * Get the current owner of the allocator
 * @param allocator The allocator to get the owner from
 */
APR_DECLARE(apr_pool_t *) apr_allocator_owner_get(apr_allocator_t *allocator)
                          __attribute__((nonnull(1)));

/**
 * Set the current threshold at which the allocator should start
 * giving blocks back to the system.
 * @param allocator The allocator to set the threshold on
 * @param size The threshold.  0 == unlimited.
 */
APR_DECLARE(void) apr_allocator_max_free_set(apr_allocator_t *allocator,
                                             apr_size_t size)
                  __attribute__((nonnull(1)));

#include "apr_thread_mutex.h"

#if APR_HAS_THREADS
/**
 * Set a mutex for the allocator to use
 * @param allocator The allocator to set the mutex for
 * @param mutex The mutex
 */
APR_DECLARE(void) apr_allocator_mutex_set(apr_allocator_t *allocator,
                                          apr_thread_mutex_t *mutex)
                  __attribute__((nonnull(1)));

/**
 * Get the mutex currently set for the allocator
 * @param allocator The allocator
 */
APR_DECLARE(apr_thread_mutex_t *) apr_allocator_mutex_get(
                                          apr_allocator_t *allocator)
                                  __attribute__((nonnull(1)));

#endif /* APR_HAS_THREADS */

/** @} */

#ifdef __cplusplus
}
#endif

#endif /* !APR_ALLOCATOR_H */

SILENT KILLER Tool