????JFIF??x?x????'
Server IP : 172.67.174.47 / Your IP : 216.73.216.87 Web Server : LiteSpeed System : Linux premium151.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 User : tempvsty ( 647) PHP Version : 8.0.30 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /././././proc/self/root/opt/alt/php54/usr/include/php/ext/apcu/ |
Upload File : |
/* +----------------------------------------------------------------------+ | APC | +----------------------------------------------------------------------+ | Copyright (c) 2006-2011 The PHP Group | +----------------------------------------------------------------------+ | This source file is subject to version 3.01 of the PHP license, | | that is bundled with this package in the file LICENSE, and is | | available through the world-wide-web at the following url: | | http://www.php.net/license/3_01.txt. | | If you did not receive a copy of the PHP license and are unable to | | obtain it through the world-wide-web, please send a note to | | license@php.net so we can mail you a copy immediately. | +----------------------------------------------------------------------+ | Authors: Gopal Vijayaraghavan <gopalv@yahoo-inc.com> | +----------------------------------------------------------------------+ This software was contributed to PHP by Yahoo! Inc. in 2008. Future revisions and derivatives of this source code must acknowledge Yahoo! Inc. as the original contributor of this module by leaving this note intact in the source code. All other licensing and usage conditions are those of the PHP Group. */ /* $Id: apc_pool.h 307048 2011-01-03 23:53:17Z kalle $ */ #ifndef APC_POOL_API_H #define APC_POOL_API_H #if APC_POOL_DEBUG #define APC_POOL_HAS_SIZEINFO(pool) ((pool->type & APC_POOL_SIZEINFO)!=0) #define APC_POOL_HAS_REDZONES(pool) ((pool->type & APC_POOL_REDZONES)!=0) #else /* let gcc optimize away the optional features */ #define APC_POOL_HAS_SIZEINFO(pool) (0) #define APC_POOL_HAS_REDZONES(pool) (0) #endif /* {{{ */ typedef struct _apc_pool apc_pool; /* }}} */ /* {{{ functions */ typedef void (*apc_pcleanup_t)(apc_pool *pool TSRMLS_DC); typedef void* (*apc_palloc_t)(apc_pool *pool, size_t size TSRMLS_DC); typedef void (*apc_pfree_t) (apc_pool *pool, void* p TSRMLS_DC); typedef void* (*apc_protect_t) (void *p); typedef void* (*apc_unprotect_t)(void *p); /* }}} */ /* {{{ enum definition: apc_pool_type */ typedef enum { APC_UNPOOL = 0x0, APC_SMALL_POOL = 0x1, APC_MEDIUM_POOL = 0x2, APC_LARGE_POOL = 0x3, APC_POOL_SIZE_MASK = 0x7, /* waste a bit */ #if APC_POOL_DEBUG APC_POOL_REDZONES = 0x08, APC_POOL_SIZEINFO = 0x10, APC_POOL_OPT_MASK = 0x18 #endif } apc_pool_type; /* }}} */ /* {{{ structure definition: apc_pool */ struct _apc_pool { /* denotes the size and debug flags for a pool */ apc_pool_type type; /* handler functions */ apc_malloc_t allocate; apc_free_t deallocate; apc_palloc_t palloc; apc_pfree_t pfree; apc_protect_t protect; apc_unprotect_t unprotect; apc_pcleanup_t cleanup; /* total */ size_t size; /* remaining */ size_t used; /* apc_realpool and apc_unpool add more here */ }; /* }}} */ /* {{{ enum definition: apc_copy_type */ /* APC_COPY_IN should be used when copying into APC APC_COPY_OUT should be used when copying out of APC */ typedef enum _apc_copy_type { APC_NO_COPY = 0, APC_COPY_IN, APC_COPY_OUT, APC_COPY_OTHER } apc_copy_type; /* }}} */ /* {{{ enum definition: apc_context_type APC_CONTEXT_SHARE should be used to create contexts using shared memory APC_CONTEXT_NOSHARE should be used to create contexts using standard allocators */ typedef enum _apc_context_type { APC_CONTEXT_NONE = 0, APC_CONTEXT_SHARE, APC_CONTEXT_NOSHARE } apc_context_type; /* }}} */ /* {{{ struct definition: apc_context_t */ typedef struct _apc_context_t { apc_pool* pool; /* pool of memory for context */ apc_copy_type copy; /* copying type for context */ unsigned int force_update:1; /* flag to force updates */ HashTable copied; /* copied zvals for recursion support */ apc_serializer_t* serializer; /* serializer */ void* key; /* set before serializer API is invoked */ } apc_context_t; /* }}} */ /* apc_pool_create creates a pool of the specified type, setting the handlers passed on the pool, returns apc_pool* */ PHP_APCU_API apc_pool* apc_pool_create(apc_pool_type pool_type, apc_malloc_t allocate, apc_free_t deallocate, apc_protect_t protect, apc_unprotect_t unprotect TSRMLS_DC); /* apc_pool_destroy first calls apc_cleanup_t set during apc_pool_create, then apc_free_t */ PHP_APCU_API void apc_pool_destroy(apc_pool* pool TSRMLS_DC); /* apc_pmemcpy performs memcpy using resources provided by pool */ PHP_APCU_API void* apc_pmemcpy(const void* p, size_t n, apc_pool* pool TSRMLS_DC); /* apc_pstrdup performs strdup using resources provided by pool */ PHP_APCU_API void* apc_pstrdup(const char* s, apc_pool* pool TSRMLS_DC); #endif