apr-commits mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From bo...@apache.org
Subject svn commit: r686480 [16/30] - in /apr/site/trunk/docs/docs: apr-util/1.3/ apr-util/trunk/ apr/1.3/ apr/trunk/
Date Sat, 16 Aug 2008 11:44:00 GMT
Modified: apr/site/trunk/docs/docs/apr/1.3/apr__pools_8h-source.html
URL: http://svn.apache.org/viewvc/apr/site/trunk/docs/docs/apr/1.3/apr__pools_8h-source.html?rev=686480&r1=686479&r2=686480&view=diff
==============================================================================
--- apr/site/trunk/docs/docs/apr/1.3/apr__pools_8h-source.html (original)
+++ apr/site/trunk/docs/docs/apr/1.3/apr__pools_8h-source.html Sat Aug 16 04:43:44 2008
@@ -4,7 +4,7 @@
 <link href="doxygen.css" rel="stylesheet" type="text/css">
 <link href="tabs.css" rel="stylesheet" type="text/css">
 </head><body>
-<!-- Generated by Doxygen 1.5.5 -->
+<!-- Generated by Doxygen 1.5.6 -->
 <div class="navigation" id="top">
   <div class="tabs">
     <ul>
@@ -208,558 +208,591 @@
 <a name="l00190"></a>00190 <span class="comment"></span>
 <a name="l00191"></a>00191 <span class="comment">/**</span>
 <a name="l00192"></a>00192 <span class="comment"> * Create a new pool.</span>
-<a name="l00193"></a>00193 <span class="comment"> * @param newpool The pool we have just created.</span>
-<a name="l00194"></a>00194 <span class="comment"> * @param abort_fn A function to use if the pool cannot allocate more memory.</span>
-<a name="l00195"></a>00195 <span class="comment"> * @param allocator The allocator to use with the new pool.  If NULL the</span>
-<a name="l00196"></a>00196 <span class="comment"> *        new allocator will be crated with newpool as owner.</span>
-<a name="l00197"></a>00197 <span class="comment"> */</span>
-<a name="l00198"></a>00198 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g20e514c83555398acddc30c4dfa0c540">apr_pool_create_core_ex</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
-<a name="l00199"></a>00199                                                   <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
-<a name="l00200"></a>00200                                                   <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator);
-<a name="l00201"></a>00201 <span class="comment"></span>
-<a name="l00202"></a>00202 <span class="comment">/**</span>
-<a name="l00203"></a>00203 <span class="comment"> * Debug version of apr_pool_create_ex.</span>
-<a name="l00204"></a>00204 <span class="comment"> * @param newpool @see apr_pool_create.</span>
-<a name="l00205"></a>00205 <span class="comment"> * @param parent @see apr_pool_create.</span>
-<a name="l00206"></a>00206 <span class="comment"> * @param abort_fn @see apr_pool_create.</span>
-<a name="l00207"></a>00207 <span class="comment"> * @param allocator @see apr_pool_create.</span>
-<a name="l00208"></a>00208 <span class="comment"> * @param file_line Where the function is called from.</span>
-<a name="l00209"></a>00209 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
-<a name="l00210"></a>00210 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
-<a name="l00211"></a>00211 <span class="comment"> *         Call this directly if you have you apr_pool_create_ex</span>
-<a name="l00212"></a>00212 <span class="comment"> *         calls in a wrapper function and wish to override</span>
-<a name="l00213"></a>00213 <span class="comment"> *         the file_line argument to reflect the caller of</span>
-<a name="l00214"></a>00214 <span class="comment"> *         your wrapper function.  If you do not have</span>
-<a name="l00215"></a>00215 <span class="comment"> *         apr_pool_create_ex in a wrapper, trust the macro</span>
-<a name="l00216"></a>00216 <span class="comment"> *         and don't call apr_pool_create_ex_debug directly.</span>
-<a name="l00217"></a>00217 <span class="comment"> */</span>
-<a name="l00218"></a>00218 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gcbea97ae5c0c861f6b7c147d46ac1d0c">apr_pool_create_ex_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
-<a name="l00219"></a>00219                                                    <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *parent,
-<a name="l00220"></a>00220                                                    <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
-<a name="l00221"></a>00221                                                    <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator,
-<a name="l00222"></a>00222                                                    const <span class="keywordtype">char</span> *file_line);
-<a name="l00223"></a>00223 
-<a name="l00224"></a>00224 <span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00225"></a>00225 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_ex(newpool, parent, abort_fn, allocator)  \</span>
-<a name="l00226"></a>00226 <span class="preprocessor">    apr_pool_create_ex_debug(newpool, parent, abort_fn, allocator, \</span>
-<a name="l00227"></a>00227 <span class="preprocessor">                             APR_POOL__FILE_LINE__)</span>
-<a name="l00228"></a>00228 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00229"></a>00229 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00230"></a>00230 <span class="comment">/**</span>
-<a name="l00231"></a>00231 <span class="comment"> * Debug version of apr_pool_create_core_ex.</span>
-<a name="l00232"></a>00232 <span class="comment"> * @param newpool @see apr_pool_create.</span>
-<a name="l00233"></a>00233 <span class="comment"> * @param abort_fn @see apr_pool_create.</span>
-<a name="l00234"></a>00234 <span class="comment"> * @param allocator @see apr_pool_create.</span>
-<a name="l00235"></a>00235 <span class="comment"> * @param file_line Where the function is called from.</span>
-<a name="l00236"></a>00236 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
-<a name="l00237"></a>00237 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
-<a name="l00238"></a>00238 <span class="comment"> *         Call this directly if you have you apr_pool_create_core_ex</span>
-<a name="l00239"></a>00239 <span class="comment"> *         calls in a wrapper function and wish to override</span>
-<a name="l00240"></a>00240 <span class="comment"> *         the file_line argument to reflect the caller of</span>
-<a name="l00241"></a>00241 <span class="comment"> *         your wrapper function.  If you do not have</span>
-<a name="l00242"></a>00242 <span class="comment"> *         apr_pool_create_core_ex in a wrapper, trust the macro</span>
-<a name="l00243"></a>00243 <span class="comment"> *         and don't call apr_pool_create_core_ex_debug directly.</span>
-<a name="l00244"></a>00244 <span class="comment"> */</span>
-<a name="l00245"></a>00245 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#ga1c5bfc44188884bb439670f81448c20">apr_pool_create_core_ex_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
-<a name="l00246"></a>00246                                                    <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
-<a name="l00247"></a>00247                                                    <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator,
-<a name="l00248"></a>00248                                                    const <span class="keywordtype">char</span> *file_line);
-<a name="l00249"></a>00249 
-<a name="l00250"></a>00250 <span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00251"></a>00251 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_core_ex(newpool, abort_fn, allocator)  \</span>
-<a name="l00252"></a>00252 <span class="preprocessor">    apr_pool_create_core_ex_debug(newpool, abort_fn, allocator, \</span>
-<a name="l00253"></a>00253 <span class="preprocessor">                                  APR_POOL__FILE_LINE__)</span>
-<a name="l00254"></a>00254 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00255"></a>00255 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00256"></a>00256 <span class="comment">/**</span>
-<a name="l00257"></a>00257 <span class="comment"> * Create a new pool.</span>
-<a name="l00258"></a>00258 <span class="comment"> * @param newpool The pool we have just created.</span>
-<a name="l00259"></a>00259 <span class="comment"> * @param parent The parent pool.  If this is NULL, the new pool is a root</span>
-<a name="l00260"></a>00260 <span class="comment"> *        pool.  If it is non-NULL, the new pool will inherit all</span>
-<a name="l00261"></a>00261 <span class="comment"> *        of its parent pool's attributes, except the apr_pool_t will</span>
-<a name="l00262"></a>00262 <span class="comment"> *        be a sub-pool.</span>
-<a name="l00263"></a>00263 <span class="comment"> */</span>
-<a name="l00264"></a>00264 <span class="preprocessor">#if defined(DOXYGEN)</span>
-<a name="l00265"></a>00265 <span class="preprocessor"></span><a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g918adf3026c894efeae254a0446aed3b">apr_pool_create</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
-<a name="l00266"></a>00266                                           <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *parent);
-<a name="l00267"></a>00267 <span class="preprocessor">#else</span>
-<a name="l00268"></a>00268 <span class="preprocessor"></span><span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00269"></a>00269 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create(newpool, parent) \</span>
-<a name="l00270"></a>00270 <span class="preprocessor">    apr_pool_create_ex_debug(newpool, parent, NULL, NULL, \</span>
-<a name="l00271"></a>00271 <span class="preprocessor">                             APR_POOL__FILE_LINE__)</span>
-<a name="l00272"></a>00272 <span class="preprocessor"></span><span class="preprocessor">#else</span>
-<a name="l00273"></a>00273 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create(newpool, parent) \</span>
-<a name="l00274"></a>00274 <span class="preprocessor">    apr_pool_create_ex(newpool, parent, NULL, NULL)</span>
-<a name="l00275"></a>00275 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00276"></a>00276 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00277"></a>00277 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00278"></a>00278 <span class="comment">/**</span>
-<a name="l00279"></a>00279 <span class="comment"> * Create a new pool.</span>
-<a name="l00280"></a>00280 <span class="comment"> * @param newpool The pool we have just created.</span>
-<a name="l00281"></a>00281 <span class="comment"> */</span>
-<a name="l00282"></a>00282 <span class="preprocessor">#if defined(DOXYGEN)</span>
-<a name="l00283"></a>00283 <span class="preprocessor"></span><a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gd3675378924bc9d98e46258c049f1761">apr_pool_create_core</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool);
-<a name="l00284"></a>00284 <span class="preprocessor">#else</span>
-<a name="l00285"></a>00285 <span class="preprocessor"></span><span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00286"></a>00286 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_core(newpool) \</span>
-<a name="l00287"></a>00287 <span class="preprocessor">    apr_pool_create_core_ex_debug(newpool, NULL, NULL, \</span>
-<a name="l00288"></a>00288 <span class="preprocessor">                                  APR_POOL__FILE_LINE__)</span>
-<a name="l00289"></a>00289 <span class="preprocessor"></span><span class="preprocessor">#else</span>
-<a name="l00290"></a>00290 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_core(newpool) \</span>
-<a name="l00291"></a>00291 <span class="preprocessor">    apr_pool_create_core_ex(newpool, NULL, NULL)</span>
-<a name="l00292"></a>00292 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00293"></a>00293 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00294"></a>00294 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00295"></a>00295 <span class="comment">/**</span>
-<a name="l00296"></a>00296 <span class="comment"> * Find the pools allocator</span>
-<a name="l00297"></a>00297 <span class="comment"> * @param pool The pool to get the allocator from.</span>
-<a name="l00298"></a>00298 <span class="comment"> */</span>
-<a name="l00299"></a>00299 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *) <a class="code" href="group__apr__pools.html#gf446fcf5da1fcd62d3f802a4c0c10f97">apr_pool_allocator_get</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00300"></a>00300 <span class="comment"></span>
-<a name="l00301"></a>00301 <span class="comment">/**</span>
-<a name="l00302"></a>00302 <span class="comment"> * Clear all memory in the pool and run all the cleanups. This also destroys all</span>
-<a name="l00303"></a>00303 <span class="comment"> * subpools.</span>
-<a name="l00304"></a>00304 <span class="comment"> * @param p The pool to clear</span>
-<a name="l00305"></a>00305 <span class="comment"> * @remark This does not actually free the memory, it just allows the pool</span>
-<a name="l00306"></a>00306 <span class="comment"> *         to re-use this memory for the next allocation.</span>
-<a name="l00307"></a>00307 <span class="comment"> * @see apr_pool_destroy()</span>
+<a name="l00193"></a>00193 <span class="comment"> * @deprecated @see apr_pool_create_unmanaged_ex.</span>
+<a name="l00194"></a>00194 <span class="comment"> */</span>
+<a name="l00195"></a>00195 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g20e514c83555398acddc30c4dfa0c540">apr_pool_create_core_ex</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
+<a name="l00196"></a>00196                                                   <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
+<a name="l00197"></a>00197                                                   <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator);
+<a name="l00198"></a>00198 <span class="comment"></span>
+<a name="l00199"></a>00199 <span class="comment">/**</span>
+<a name="l00200"></a>00200 <span class="comment"> * Create a new unmanaged pool.</span>
+<a name="l00201"></a>00201 <span class="comment"> * @param newpool The pool we have just created.</span>
+<a name="l00202"></a>00202 <span class="comment"> * @param abort_fn A function to use if the pool cannot allocate more memory.</span>
+<a name="l00203"></a>00203 <span class="comment"> * @param allocator The allocator to use with the new pool.  If NULL a</span>
+<a name="l00204"></a>00204 <span class="comment"> *        new allocator will be crated with newpool as owner.</span>
+<a name="l00205"></a>00205 <span class="comment"> * @remark An unmanaged pool is a special pool without a parent; it will</span>
+<a name="l00206"></a>00206 <span class="comment"> *         NOT be destroyed upon apr_terminate.  It must be explicitly</span>
+<a name="l00207"></a>00207 <span class="comment"> *         destroyed by calling apr_pool_destroy, to prevent memory leaks.</span>
+<a name="l00208"></a>00208 <span class="comment"> *         Use of this function is discouraged, think twice about whether</span>
+<a name="l00209"></a>00209 <span class="comment"> *         you really really need it.</span>
+<a name="l00210"></a>00210 <span class="comment"> */</span>
+<a name="l00211"></a>00211 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gae7212db77bb57f86419cd594f73a92f">apr_pool_create_unmanaged_ex</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
+<a name="l00212"></a>00212                                                    <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
+<a name="l00213"></a>00213                                                    <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator);
+<a name="l00214"></a>00214 <span class="comment"></span>
+<a name="l00215"></a>00215 <span class="comment">/**</span>
+<a name="l00216"></a>00216 <span class="comment"> * Debug version of apr_pool_create_ex.</span>
+<a name="l00217"></a>00217 <span class="comment"> * @param newpool @see apr_pool_create.</span>
+<a name="l00218"></a>00218 <span class="comment"> * @param parent @see apr_pool_create.</span>
+<a name="l00219"></a>00219 <span class="comment"> * @param abort_fn @see apr_pool_create.</span>
+<a name="l00220"></a>00220 <span class="comment"> * @param allocator @see apr_pool_create.</span>
+<a name="l00221"></a>00221 <span class="comment"> * @param file_line Where the function is called from.</span>
+<a name="l00222"></a>00222 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
+<a name="l00223"></a>00223 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
+<a name="l00224"></a>00224 <span class="comment"> *         Call this directly if you have you apr_pool_create_ex</span>
+<a name="l00225"></a>00225 <span class="comment"> *         calls in a wrapper function and wish to override</span>
+<a name="l00226"></a>00226 <span class="comment"> *         the file_line argument to reflect the caller of</span>
+<a name="l00227"></a>00227 <span class="comment"> *         your wrapper function.  If you do not have</span>
+<a name="l00228"></a>00228 <span class="comment"> *         apr_pool_create_ex in a wrapper, trust the macro</span>
+<a name="l00229"></a>00229 <span class="comment"> *         and don't call apr_pool_create_ex_debug directly.</span>
+<a name="l00230"></a>00230 <span class="comment"> */</span>
+<a name="l00231"></a>00231 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gcbea97ae5c0c861f6b7c147d46ac1d0c">apr_pool_create_ex_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
+<a name="l00232"></a>00232                                                    <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *parent,
+<a name="l00233"></a>00233                                                    <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
+<a name="l00234"></a>00234                                                    <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator,
+<a name="l00235"></a>00235                                                    const <span class="keywordtype">char</span> *file_line);
+<a name="l00236"></a>00236 
+<a name="l00237"></a>00237 <span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00238"></a>00238 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_ex(newpool, parent, abort_fn, allocator)  \</span>
+<a name="l00239"></a>00239 <span class="preprocessor">    apr_pool_create_ex_debug(newpool, parent, abort_fn, allocator, \</span>
+<a name="l00240"></a>00240 <span class="preprocessor">                             APR_POOL__FILE_LINE__)</span>
+<a name="l00241"></a>00241 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00242"></a>00242 <span class="preprocessor"></span><span class="comment"></span>
+<a name="l00243"></a>00243 <span class="comment">/**</span>
+<a name="l00244"></a>00244 <span class="comment"> * Debug version of apr_pool_create_core_ex.</span>
+<a name="l00245"></a>00245 <span class="comment"> * @deprecated @see apr_pool_create_unmanaged_ex_debug.</span>
+<a name="l00246"></a>00246 <span class="comment"> */</span>
+<a name="l00247"></a>00247 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#ga1c5bfc44188884bb439670f81448c20">apr_pool_create_core_ex_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
+<a name="l00248"></a>00248                                                    <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
+<a name="l00249"></a>00249                                                    <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator,
+<a name="l00250"></a>00250                                                    const <span class="keywordtype">char</span> *file_line);
+<a name="l00251"></a>00251 <span class="comment"></span>
+<a name="l00252"></a>00252 <span class="comment">/**</span>
+<a name="l00253"></a>00253 <span class="comment"> * Debug version of apr_pool_create_unmanaged_ex.</span>
+<a name="l00254"></a>00254 <span class="comment"> * @param newpool @see apr_pool_create_unmanaged.</span>
+<a name="l00255"></a>00255 <span class="comment"> * @param abort_fn @see apr_pool_create_unmanaged.</span>
+<a name="l00256"></a>00256 <span class="comment"> * @param allocator @see apr_pool_create_unmanaged.</span>
+<a name="l00257"></a>00257 <span class="comment"> * @param file_line Where the function is called from.</span>
+<a name="l00258"></a>00258 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
+<a name="l00259"></a>00259 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
+<a name="l00260"></a>00260 <span class="comment"> *         Call this directly if you have you apr_pool_create_unmanaged_ex</span>
+<a name="l00261"></a>00261 <span class="comment"> *         calls in a wrapper function and wish to override</span>
+<a name="l00262"></a>00262 <span class="comment"> *         the file_line argument to reflect the caller of</span>
+<a name="l00263"></a>00263 <span class="comment"> *         your wrapper function.  If you do not have</span>
+<a name="l00264"></a>00264 <span class="comment"> *         apr_pool_create_core_ex in a wrapper, trust the macro</span>
+<a name="l00265"></a>00265 <span class="comment"> *         and don't call apr_pool_create_core_ex_debug directly.</span>
+<a name="l00266"></a>00266 <span class="comment"> */</span>
+<a name="l00267"></a>00267 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#ge220e572b14355f1aa7b21c8fb022524">apr_pool_create_unmanaged_ex_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
+<a name="l00268"></a>00268                                                    <a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abort_fn,
+<a name="l00269"></a>00269                                                    <a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *allocator,
+<a name="l00270"></a>00270                                                    const <span class="keywordtype">char</span> *file_line);
+<a name="l00271"></a>00271 
+<a name="l00272"></a>00272 <span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00273"></a>00273 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_core_ex(newpool, abort_fn, allocator)  \</span>
+<a name="l00274"></a>00274 <span class="preprocessor">    apr_pool_create_unmanaged_ex_debug(newpool, abort_fn, allocator, \</span>
+<a name="l00275"></a>00275 <span class="preprocessor">                                  APR_POOL__FILE_LINE__)</span>
+<a name="l00276"></a>00276 <span class="preprocessor"></span>
+<a name="l00277"></a>00277 <span class="preprocessor">#define apr_pool_create_unmanaged_ex(newpool, abort_fn, allocator)  \</span>
+<a name="l00278"></a>00278 <span class="preprocessor">    apr_pool_create_unmanaged_ex_debug(newpool, abort_fn, allocator, \</span>
+<a name="l00279"></a>00279 <span class="preprocessor">                                  APR_POOL__FILE_LINE__)</span>
+<a name="l00280"></a>00280 <span class="preprocessor"></span>
+<a name="l00281"></a>00281 <span class="preprocessor">#endif</span>
+<a name="l00282"></a>00282 <span class="preprocessor"></span><span class="comment"></span>
+<a name="l00283"></a>00283 <span class="comment">/**</span>
+<a name="l00284"></a>00284 <span class="comment"> * Create a new pool.</span>
+<a name="l00285"></a>00285 <span class="comment"> * @param newpool The pool we have just created.</span>
+<a name="l00286"></a>00286 <span class="comment"> * @param parent The parent pool.  If this is NULL, the new pool is a root</span>
+<a name="l00287"></a>00287 <span class="comment"> *        pool.  If it is non-NULL, the new pool will inherit all</span>
+<a name="l00288"></a>00288 <span class="comment"> *        of its parent pool's attributes, except the apr_pool_t will</span>
+<a name="l00289"></a>00289 <span class="comment"> *        be a sub-pool.</span>
+<a name="l00290"></a>00290 <span class="comment"> */</span>
+<a name="l00291"></a>00291 <span class="preprocessor">#if defined(DOXYGEN)</span>
+<a name="l00292"></a>00292 <span class="preprocessor"></span><a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g918adf3026c894efeae254a0446aed3b">apr_pool_create</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool,
+<a name="l00293"></a>00293                                           <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *parent);
+<a name="l00294"></a>00294 <span class="preprocessor">#else</span>
+<a name="l00295"></a>00295 <span class="preprocessor"></span><span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00296"></a>00296 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create(newpool, parent) \</span>
+<a name="l00297"></a>00297 <span class="preprocessor">    apr_pool_create_ex_debug(newpool, parent, NULL, NULL, \</span>
+<a name="l00298"></a>00298 <span class="preprocessor">                             APR_POOL__FILE_LINE__)</span>
+<a name="l00299"></a>00299 <span class="preprocessor"></span><span class="preprocessor">#else</span>
+<a name="l00300"></a>00300 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create(newpool, parent) \</span>
+<a name="l00301"></a>00301 <span class="preprocessor">    apr_pool_create_ex(newpool, parent, NULL, NULL)</span>
+<a name="l00302"></a>00302 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00303"></a>00303 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00304"></a>00304 <span class="preprocessor"></span><span class="comment"></span>
+<a name="l00305"></a>00305 <span class="comment">/**</span>
+<a name="l00306"></a>00306 <span class="comment"> * Create a new pool.</span>
+<a name="l00307"></a>00307 <span class="comment"> * @param newpool The pool we have just created.</span>
 <a name="l00308"></a>00308 <span class="comment"> */</span>
-<a name="l00309"></a>00309 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#gfa8a998cd660e82b62aecec09e239d0d">apr_pool_clear</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p);
-<a name="l00310"></a>00310 <span class="comment"></span>
-<a name="l00311"></a>00311 <span class="comment">/**</span>
-<a name="l00312"></a>00312 <span class="comment"> * Debug version of apr_pool_clear.</span>
-<a name="l00313"></a>00313 <span class="comment"> * @param p See: apr_pool_clear.</span>
-<a name="l00314"></a>00314 <span class="comment"> * @param file_line Where the function is called from.</span>
-<a name="l00315"></a>00315 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
-<a name="l00316"></a>00316 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
-<a name="l00317"></a>00317 <span class="comment"> *         Call this directly if you have you apr_pool_clear</span>
-<a name="l00318"></a>00318 <span class="comment"> *         calls in a wrapper function and wish to override</span>
-<a name="l00319"></a>00319 <span class="comment"> *         the file_line argument to reflect the caller of</span>
-<a name="l00320"></a>00320 <span class="comment"> *         your wrapper function.  If you do not have</span>
-<a name="l00321"></a>00321 <span class="comment"> *         apr_pool_clear in a wrapper, trust the macro</span>
-<a name="l00322"></a>00322 <span class="comment"> *         and don't call apr_pool_destroy_clear directly.</span>
-<a name="l00323"></a>00323 <span class="comment"> */</span>
-<a name="l00324"></a>00324 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#g9521870e42ec4395a0bf8388706a57b9">apr_pool_clear_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p,
-<a name="l00325"></a>00325                                        const <span class="keywordtype">char</span> *file_line);
-<a name="l00326"></a>00326 
-<a name="l00327"></a>00327 <span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00328"></a>00328 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_clear(p) \</span>
-<a name="l00329"></a>00329 <span class="preprocessor">    apr_pool_clear_debug(p, APR_POOL__FILE_LINE__)</span>
-<a name="l00330"></a>00330 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00331"></a>00331 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00332"></a>00332 <span class="comment">/**</span>
-<a name="l00333"></a>00333 <span class="comment"> * Destroy the pool. This takes similar action as apr_pool_clear() and then</span>
-<a name="l00334"></a>00334 <span class="comment"> * frees all the memory.</span>
-<a name="l00335"></a>00335 <span class="comment"> * @param p The pool to destroy</span>
-<a name="l00336"></a>00336 <span class="comment"> * @remark This will actually free the memory</span>
-<a name="l00337"></a>00337 <span class="comment"> */</span>
-<a name="l00338"></a>00338 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#g54759954d2cba7cb649ab5680a33f9e3">apr_pool_destroy</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p);
-<a name="l00339"></a>00339 <span class="comment"></span>
-<a name="l00340"></a>00340 <span class="comment">/**</span>
-<a name="l00341"></a>00341 <span class="comment"> * Debug version of apr_pool_destroy.</span>
-<a name="l00342"></a>00342 <span class="comment"> * @param p See: apr_pool_destroy.</span>
-<a name="l00343"></a>00343 <span class="comment"> * @param file_line Where the function is called from.</span>
-<a name="l00344"></a>00344 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
-<a name="l00345"></a>00345 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
-<a name="l00346"></a>00346 <span class="comment"> *         Call this directly if you have you apr_pool_destroy</span>
-<a name="l00347"></a>00347 <span class="comment"> *         calls in a wrapper function and wish to override</span>
-<a name="l00348"></a>00348 <span class="comment"> *         the file_line argument to reflect the caller of</span>
-<a name="l00349"></a>00349 <span class="comment"> *         your wrapper function.  If you do not have</span>
-<a name="l00350"></a>00350 <span class="comment"> *         apr_pool_destroy in a wrapper, trust the macro</span>
-<a name="l00351"></a>00351 <span class="comment"> *         and don't call apr_pool_destroy_debug directly.</span>
-<a name="l00352"></a>00352 <span class="comment"> */</span>
-<a name="l00353"></a>00353 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#g7efe64dfcce883d7fad9df813d9259fc">apr_pool_destroy_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p,
-<a name="l00354"></a>00354                                          const <span class="keywordtype">char</span> *file_line);
-<a name="l00355"></a>00355 
-<a name="l00356"></a>00356 <span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00357"></a>00357 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_destroy(p) \</span>
-<a name="l00358"></a>00358 <span class="preprocessor">    apr_pool_destroy_debug(p, APR_POOL__FILE_LINE__)</span>
-<a name="l00359"></a>00359 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00360"></a>00360 <span class="preprocessor"></span>
-<a name="l00361"></a>00361 
-<a name="l00362"></a>00362 <span class="comment">/*</span>
-<a name="l00363"></a>00363 <span class="comment"> * Memory allocation</span>
-<a name="l00364"></a>00364 <span class="comment"> */</span>
-<a name="l00365"></a>00365 <span class="comment"></span>
-<a name="l00366"></a>00366 <span class="comment">/**</span>
-<a name="l00367"></a>00367 <span class="comment"> * Allocate a block of memory from a pool</span>
-<a name="l00368"></a>00368 <span class="comment"> * @param p The pool to allocate from</span>
-<a name="l00369"></a>00369 <span class="comment"> * @param size The amount of memory to allocate</span>
-<a name="l00370"></a>00370 <span class="comment"> * @return The allocated memory</span>
-<a name="l00371"></a>00371 <span class="comment"> */</span>
-<a name="l00372"></a>00372 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#g85f1e193c31d109affda72f9a92c6915">apr_palloc</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size);
-<a name="l00373"></a>00373 <span class="comment"></span>
-<a name="l00374"></a>00374 <span class="comment">/**</span>
-<a name="l00375"></a>00375 <span class="comment"> * Debug version of apr_palloc</span>
-<a name="l00376"></a>00376 <span class="comment"> * @param p See: apr_palloc</span>
-<a name="l00377"></a>00377 <span class="comment"> * @param size See: apr_palloc</span>
-<a name="l00378"></a>00378 <span class="comment"> * @param file_line Where the function is called from.</span>
-<a name="l00379"></a>00379 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
-<a name="l00380"></a>00380 <span class="comment"> * @return See: apr_palloc</span>
-<a name="l00381"></a>00381 <span class="comment"> */</span>
-<a name="l00382"></a>00382 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#g0ac211ac89be868b107776b4183a8174">apr_palloc_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size,
-<a name="l00383"></a>00383                                      const <span class="keywordtype">char</span> *file_line);
-<a name="l00384"></a>00384 
-<a name="l00385"></a>00385 <span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00386"></a>00386 <span class="preprocessor"></span><span class="preprocessor">#define apr_palloc(p, size) \</span>
-<a name="l00387"></a>00387 <span class="preprocessor">    apr_palloc_debug(p, size, APR_POOL__FILE_LINE__)</span>
-<a name="l00388"></a>00388 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00389"></a>00389 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00390"></a>00390 <span class="comment">/**</span>
-<a name="l00391"></a>00391 <span class="comment"> * Allocate a block of memory from a pool and set all of the memory to 0</span>
-<a name="l00392"></a>00392 <span class="comment"> * @param p The pool to allocate from</span>
-<a name="l00393"></a>00393 <span class="comment"> * @param size The amount of memory to allocate</span>
-<a name="l00394"></a>00394 <span class="comment"> * @return The allocated memory</span>
-<a name="l00395"></a>00395 <span class="comment"> */</span>
-<a name="l00396"></a>00396 <span class="preprocessor">#if defined(DOXYGEN)</span>
-<a name="l00397"></a>00397 <span class="preprocessor"></span><a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#gf61c098ad258069d64cdf8c0a9369f9e">apr_pcalloc</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size);
-<a name="l00398"></a>00398 <span class="preprocessor">#elif !APR_POOL_DEBUG</span>
-<a name="l00399"></a>00399 <span class="preprocessor"></span><span class="preprocessor">#define apr_pcalloc(p, size) memset(apr_palloc(p, size), 0, size)</span>
-<a name="l00400"></a>00400 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00401"></a>00401 <span class="preprocessor"></span><span class="comment"></span>
-<a name="l00402"></a>00402 <span class="comment">/**</span>
-<a name="l00403"></a>00403 <span class="comment"> * Debug version of apr_pcalloc</span>
-<a name="l00404"></a>00404 <span class="comment"> * @param p See: apr_pcalloc</span>
-<a name="l00405"></a>00405 <span class="comment"> * @param size See: apr_pcalloc</span>
-<a name="l00406"></a>00406 <span class="comment"> * @param file_line Where the function is called from.</span>
-<a name="l00407"></a>00407 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
-<a name="l00408"></a>00408 <span class="comment"> * @return See: apr_pcalloc</span>
-<a name="l00409"></a>00409 <span class="comment"> */</span>
-<a name="l00410"></a>00410 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#g7b43035318ffdc57a6eddab07dc57cb2">apr_pcalloc_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size,
-<a name="l00411"></a>00411                                       const <span class="keywordtype">char</span> *file_line);
-<a name="l00412"></a>00412 
-<a name="l00413"></a>00413 <span class="preprocessor">#if APR_POOL_DEBUG</span>
-<a name="l00414"></a>00414 <span class="preprocessor"></span><span class="preprocessor">#define apr_pcalloc(p, size) \</span>
-<a name="l00415"></a>00415 <span class="preprocessor">    apr_pcalloc_debug(p, size, APR_POOL__FILE_LINE__)</span>
-<a name="l00416"></a>00416 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
-<a name="l00417"></a>00417 <span class="preprocessor"></span>
-<a name="l00418"></a>00418 
-<a name="l00419"></a>00419 <span class="comment">/*</span>
-<a name="l00420"></a>00420 <span class="comment"> * Pool Properties</span>
-<a name="l00421"></a>00421 <span class="comment"> */</span>
-<a name="l00422"></a>00422 <span class="comment"></span>
+<a name="l00309"></a>00309 <span class="preprocessor">#if defined(DOXYGEN)</span>
+<a name="l00310"></a>00310 <span class="preprocessor"></span><a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gd3675378924bc9d98e46258c049f1761">apr_pool_create_core</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool);
+<a name="l00311"></a>00311 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) apr_pool_create_unmanaged(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> **newpool);
+<a name="l00312"></a>00312 <span class="preprocessor">#else</span>
+<a name="l00313"></a>00313 <span class="preprocessor"></span><span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00314"></a>00314 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_core(newpool) \</span>
+<a name="l00315"></a>00315 <span class="preprocessor">    apr_pool_create_unmanaged_ex_debug(newpool, NULL, NULL, \</span>
+<a name="l00316"></a>00316 <span class="preprocessor">                                  APR_POOL__FILE_LINE__)</span>
+<a name="l00317"></a>00317 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_unmanaged(newpool) \</span>
+<a name="l00318"></a>00318 <span class="preprocessor">    apr_pool_create_unmanaged_ex_debug(newpool, NULL, NULL, \</span>
+<a name="l00319"></a>00319 <span class="preprocessor">                                  APR_POOL__FILE_LINE__)</span>
+<a name="l00320"></a>00320 <span class="preprocessor"></span><span class="preprocessor">#else</span>
+<a name="l00321"></a>00321 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_core(newpool) \</span>
+<a name="l00322"></a>00322 <span class="preprocessor">    apr_pool_create_unmanaged_ex(newpool, NULL, NULL)</span>
+<a name="l00323"></a>00323 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_create_unmanaged(newpool) \</span>
+<a name="l00324"></a>00324 <span class="preprocessor">    apr_pool_create_unmanaged_ex(newpool, NULL, NULL)</span>
+<a name="l00325"></a>00325 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00326"></a>00326 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00327"></a>00327 <span class="preprocessor"></span><span class="comment"></span>
+<a name="l00328"></a>00328 <span class="comment">/**</span>
+<a name="l00329"></a>00329 <span class="comment"> * Find the pools allocator</span>
+<a name="l00330"></a>00330 <span class="comment"> * @param pool The pool to get the allocator from.</span>
+<a name="l00331"></a>00331 <span class="comment"> */</span>
+<a name="l00332"></a>00332 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__allocator.html#g1ceabfd30fcfc455e47d052d2a24244b">apr_allocator_t</a> *) <a class="code" href="group__apr__pools.html#gf446fcf5da1fcd62d3f802a4c0c10f97">apr_pool_allocator_get</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00333"></a>00333 <span class="comment"></span>
+<a name="l00334"></a>00334 <span class="comment">/**</span>
+<a name="l00335"></a>00335 <span class="comment"> * Clear all memory in the pool and run all the cleanups. This also destroys all</span>
+<a name="l00336"></a>00336 <span class="comment"> * subpools.</span>
+<a name="l00337"></a>00337 <span class="comment"> * @param p The pool to clear</span>
+<a name="l00338"></a>00338 <span class="comment"> * @remark This does not actually free the memory, it just allows the pool</span>
+<a name="l00339"></a>00339 <span class="comment"> *         to re-use this memory for the next allocation.</span>
+<a name="l00340"></a>00340 <span class="comment"> * @see apr_pool_destroy()</span>
+<a name="l00341"></a>00341 <span class="comment"> */</span>
+<a name="l00342"></a>00342 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#gfa8a998cd660e82b62aecec09e239d0d">apr_pool_clear</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p);
+<a name="l00343"></a>00343 <span class="comment"></span>
+<a name="l00344"></a>00344 <span class="comment">/**</span>
+<a name="l00345"></a>00345 <span class="comment"> * Debug version of apr_pool_clear.</span>
+<a name="l00346"></a>00346 <span class="comment"> * @param p See: apr_pool_clear.</span>
+<a name="l00347"></a>00347 <span class="comment"> * @param file_line Where the function is called from.</span>
+<a name="l00348"></a>00348 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
+<a name="l00349"></a>00349 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
+<a name="l00350"></a>00350 <span class="comment"> *         Call this directly if you have you apr_pool_clear</span>
+<a name="l00351"></a>00351 <span class="comment"> *         calls in a wrapper function and wish to override</span>
+<a name="l00352"></a>00352 <span class="comment"> *         the file_line argument to reflect the caller of</span>
+<a name="l00353"></a>00353 <span class="comment"> *         your wrapper function.  If you do not have</span>
+<a name="l00354"></a>00354 <span class="comment"> *         apr_pool_clear in a wrapper, trust the macro</span>
+<a name="l00355"></a>00355 <span class="comment"> *         and don't call apr_pool_destroy_clear directly.</span>
+<a name="l00356"></a>00356 <span class="comment"> */</span>
+<a name="l00357"></a>00357 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#g9521870e42ec4395a0bf8388706a57b9">apr_pool_clear_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p,
+<a name="l00358"></a>00358                                        const <span class="keywordtype">char</span> *file_line);
+<a name="l00359"></a>00359 
+<a name="l00360"></a>00360 <span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00361"></a>00361 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_clear(p) \</span>
+<a name="l00362"></a>00362 <span class="preprocessor">    apr_pool_clear_debug(p, APR_POOL__FILE_LINE__)</span>
+<a name="l00363"></a>00363 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00364"></a>00364 <span class="preprocessor"></span><span class="comment"></span>
+<a name="l00365"></a>00365 <span class="comment">/**</span>
+<a name="l00366"></a>00366 <span class="comment"> * Destroy the pool. This takes similar action as apr_pool_clear() and then</span>
+<a name="l00367"></a>00367 <span class="comment"> * frees all the memory.</span>
+<a name="l00368"></a>00368 <span class="comment"> * @param p The pool to destroy</span>
+<a name="l00369"></a>00369 <span class="comment"> * @remark This will actually free the memory</span>
+<a name="l00370"></a>00370 <span class="comment"> */</span>
+<a name="l00371"></a>00371 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#g54759954d2cba7cb649ab5680a33f9e3">apr_pool_destroy</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p);
+<a name="l00372"></a>00372 <span class="comment"></span>
+<a name="l00373"></a>00373 <span class="comment">/**</span>
+<a name="l00374"></a>00374 <span class="comment"> * Debug version of apr_pool_destroy.</span>
+<a name="l00375"></a>00375 <span class="comment"> * @param p See: apr_pool_destroy.</span>
+<a name="l00376"></a>00376 <span class="comment"> * @param file_line Where the function is called from.</span>
+<a name="l00377"></a>00377 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
+<a name="l00378"></a>00378 <span class="comment"> * @remark Only available when APR_POOL_DEBUG is defined.</span>
+<a name="l00379"></a>00379 <span class="comment"> *         Call this directly if you have you apr_pool_destroy</span>
+<a name="l00380"></a>00380 <span class="comment"> *         calls in a wrapper function and wish to override</span>
+<a name="l00381"></a>00381 <span class="comment"> *         the file_line argument to reflect the caller of</span>
+<a name="l00382"></a>00382 <span class="comment"> *         your wrapper function.  If you do not have</span>
+<a name="l00383"></a>00383 <span class="comment"> *         apr_pool_destroy in a wrapper, trust the macro</span>
+<a name="l00384"></a>00384 <span class="comment"> *         and don't call apr_pool_destroy_debug directly.</span>
+<a name="l00385"></a>00385 <span class="comment"> */</span>
+<a name="l00386"></a>00386 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#g7efe64dfcce883d7fad9df813d9259fc">apr_pool_destroy_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p,
+<a name="l00387"></a>00387                                          const <span class="keywordtype">char</span> *file_line);
+<a name="l00388"></a>00388 
+<a name="l00389"></a>00389 <span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00390"></a>00390 <span class="preprocessor"></span><span class="preprocessor">#define apr_pool_destroy(p) \</span>
+<a name="l00391"></a>00391 <span class="preprocessor">    apr_pool_destroy_debug(p, APR_POOL__FILE_LINE__)</span>
+<a name="l00392"></a>00392 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00393"></a>00393 <span class="preprocessor"></span>
+<a name="l00394"></a>00394 
+<a name="l00395"></a>00395 <span class="comment">/*</span>
+<a name="l00396"></a>00396 <span class="comment"> * Memory allocation</span>
+<a name="l00397"></a>00397 <span class="comment"> */</span>
+<a name="l00398"></a>00398 <span class="comment"></span>
+<a name="l00399"></a>00399 <span class="comment">/**</span>
+<a name="l00400"></a>00400 <span class="comment"> * Allocate a block of memory from a pool</span>
+<a name="l00401"></a>00401 <span class="comment"> * @param p The pool to allocate from</span>
+<a name="l00402"></a>00402 <span class="comment"> * @param size The amount of memory to allocate</span>
+<a name="l00403"></a>00403 <span class="comment"> * @return The allocated memory</span>
+<a name="l00404"></a>00404 <span class="comment"> */</span>
+<a name="l00405"></a>00405 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#g85f1e193c31d109affda72f9a92c6915">apr_palloc</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size);
+<a name="l00406"></a>00406 <span class="comment"></span>
+<a name="l00407"></a>00407 <span class="comment">/**</span>
+<a name="l00408"></a>00408 <span class="comment"> * Debug version of apr_palloc</span>
+<a name="l00409"></a>00409 <span class="comment"> * @param p See: apr_palloc</span>
+<a name="l00410"></a>00410 <span class="comment"> * @param size See: apr_palloc</span>
+<a name="l00411"></a>00411 <span class="comment"> * @param file_line Where the function is called from.</span>
+<a name="l00412"></a>00412 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
+<a name="l00413"></a>00413 <span class="comment"> * @return See: apr_palloc</span>
+<a name="l00414"></a>00414 <span class="comment"> */</span>
+<a name="l00415"></a>00415 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#g0ac211ac89be868b107776b4183a8174">apr_palloc_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size,
+<a name="l00416"></a>00416                                      const <span class="keywordtype">char</span> *file_line);
+<a name="l00417"></a>00417 
+<a name="l00418"></a>00418 <span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00419"></a>00419 <span class="preprocessor"></span><span class="preprocessor">#define apr_palloc(p, size) \</span>
+<a name="l00420"></a>00420 <span class="preprocessor">    apr_palloc_debug(p, size, APR_POOL__FILE_LINE__)</span>
+<a name="l00421"></a>00421 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00422"></a>00422 <span class="preprocessor"></span><span class="comment"></span>
 <a name="l00423"></a>00423 <span class="comment">/**</span>
-<a name="l00424"></a>00424 <span class="comment"> * Set the function to be called when an allocation failure occurs.</span>
-<a name="l00425"></a>00425 <span class="comment"> * @remark If the program wants APR to exit on a memory allocation error,</span>
-<a name="l00426"></a>00426 <span class="comment"> *      then this function can be called to set the callback to use (for</span>
-<a name="l00427"></a>00427 <span class="comment"> *      performing cleanup and then exiting). If this function is not called,</span>
-<a name="l00428"></a>00428 <span class="comment"> *      then APR will return an error and expect the calling program to</span>
-<a name="l00429"></a>00429 <span class="comment"> *      deal with the error accordingly.</span>
-<a name="l00430"></a>00430 <span class="comment"> */</span>
-<a name="l00431"></a>00431 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#ga658b1f10dd13967eaa7c4156d4c2174">apr_pool_abort_set</a>(<a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abortfunc,
-<a name="l00432"></a>00432                                      <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00433"></a>00433 <span class="comment"></span>
-<a name="l00434"></a>00434 <span class="comment">/**</span>
-<a name="l00435"></a>00435 <span class="comment"> * Get the abort function associated with the specified pool.</span>
-<a name="l00436"></a>00436 <span class="comment"> * @param pool The pool for retrieving the abort function.</span>
-<a name="l00437"></a>00437 <span class="comment"> * @return The abort function for the given pool.</span>
-<a name="l00438"></a>00438 <span class="comment"> */</span>
-<a name="l00439"></a>00439 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a>) <a class="code" href="group__apr__pools.html#gf7610c30ef5f84a8742c0b3e63fdd7b0">apr_pool_abort_get</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00440"></a>00440 <span class="comment"></span>
-<a name="l00441"></a>00441 <span class="comment">/**</span>
-<a name="l00442"></a>00442 <span class="comment"> * Get the parent pool of the specified pool.</span>
-<a name="l00443"></a>00443 <span class="comment"> * @param pool The pool for retrieving the parent pool.</span>
-<a name="l00444"></a>00444 <span class="comment"> * @return The parent of the given pool.</span>
-<a name="l00445"></a>00445 <span class="comment"> */</span>
-<a name="l00446"></a>00446 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *) <a class="code" href="group__apr__pools.html#g94db31f40609b15b592ff47f989ca9ec">apr_pool_parent_get</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00447"></a>00447 <span class="comment"></span>
-<a name="l00448"></a>00448 <span class="comment">/**</span>
-<a name="l00449"></a>00449 <span class="comment"> * Determine if pool a is an ancestor of pool b.</span>
-<a name="l00450"></a>00450 <span class="comment"> * @param a The pool to search</span>
-<a name="l00451"></a>00451 <span class="comment"> * @param b The pool to search for</span>
-<a name="l00452"></a>00452 <span class="comment"> * @return True if a is an ancestor of b, NULL is considered an ancestor</span>
-<a name="l00453"></a>00453 <span class="comment"> *         of all pools.</span>
-<a name="l00454"></a>00454 <span class="comment"> * @remark if compiled with APR_POOL_DEBUG, this function will also</span>
-<a name="l00455"></a>00455 <span class="comment"> * return true if A is a pool which has been guaranteed by the caller</span>
-<a name="l00456"></a>00456 <span class="comment"> * (using apr_pool_join) to have a lifetime at least as long as some</span>
-<a name="l00457"></a>00457 <span class="comment"> * ancestor of pool B.</span>
-<a name="l00458"></a>00458 <span class="comment"> */</span>
-<a name="l00459"></a>00459 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">int</span>) <a class="code" href="group__apr__pools.html#g05d299f778659d1e0806140d8a7fea79">apr_pool_is_ancestor</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *a, <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *b);
-<a name="l00460"></a>00460 <span class="comment"></span>
-<a name="l00461"></a>00461 <span class="comment">/**</span>
-<a name="l00462"></a>00462 <span class="comment"> * Tag a pool (give it a name)</span>
-<a name="l00463"></a>00463 <span class="comment"> * @param pool The pool to tag</span>
-<a name="l00464"></a>00464 <span class="comment"> * @param tag  The tag</span>
-<a name="l00465"></a>00465 <span class="comment"> */</span>
-<a name="l00466"></a>00466 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#geaa872f7999740a60803e95429890518">apr_pool_tag</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool, const <span class="keywordtype">char</span> *tag);
-<a name="l00467"></a>00467 
-<a name="l00468"></a>00468 
-<a name="l00469"></a>00469 <span class="comment">/*</span>
-<a name="l00470"></a>00470 <span class="comment"> * User data management</span>
+<a name="l00424"></a>00424 <span class="comment"> * Allocate a block of memory from a pool and set all of the memory to 0</span>
+<a name="l00425"></a>00425 <span class="comment"> * @param p The pool to allocate from</span>
+<a name="l00426"></a>00426 <span class="comment"> * @param size The amount of memory to allocate</span>
+<a name="l00427"></a>00427 <span class="comment"> * @return The allocated memory</span>
+<a name="l00428"></a>00428 <span class="comment"> */</span>
+<a name="l00429"></a>00429 <span class="preprocessor">#if defined(DOXYGEN)</span>
+<a name="l00430"></a>00430 <span class="preprocessor"></span><a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#gf61c098ad258069d64cdf8c0a9369f9e">apr_pcalloc</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size);
+<a name="l00431"></a>00431 <span class="preprocessor">#elif !APR_POOL_DEBUG</span>
+<a name="l00432"></a>00432 <span class="preprocessor"></span><span class="preprocessor">#define apr_pcalloc(p, size) memset(apr_palloc(p, size), 0, size)</span>
+<a name="l00433"></a>00433 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00434"></a>00434 <span class="preprocessor"></span><span class="comment"></span>
+<a name="l00435"></a>00435 <span class="comment">/**</span>
+<a name="l00436"></a>00436 <span class="comment"> * Debug version of apr_pcalloc</span>
+<a name="l00437"></a>00437 <span class="comment"> * @param p See: apr_pcalloc</span>
+<a name="l00438"></a>00438 <span class="comment"> * @param size See: apr_pcalloc</span>
+<a name="l00439"></a>00439 <span class="comment"> * @param file_line Where the function is called from.</span>
+<a name="l00440"></a>00440 <span class="comment"> *        This is usually APR_POOL__FILE_LINE__.</span>
+<a name="l00441"></a>00441 <span class="comment"> * @return See: apr_pcalloc</span>
+<a name="l00442"></a>00442 <span class="comment"> */</span>
+<a name="l00443"></a>00443 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span> *) <a class="code" href="group__apr__pools.html#g7b43035318ffdc57a6eddab07dc57cb2">apr_pcalloc_debug</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p, apr_size_t size,
+<a name="l00444"></a>00444                                       const <span class="keywordtype">char</span> *file_line);
+<a name="l00445"></a>00445 
+<a name="l00446"></a>00446 <span class="preprocessor">#if APR_POOL_DEBUG</span>
+<a name="l00447"></a>00447 <span class="preprocessor"></span><span class="preprocessor">#define apr_pcalloc(p, size) \</span>
+<a name="l00448"></a>00448 <span class="preprocessor">    apr_pcalloc_debug(p, size, APR_POOL__FILE_LINE__)</span>
+<a name="l00449"></a>00449 <span class="preprocessor"></span><span class="preprocessor">#endif</span>
+<a name="l00450"></a>00450 <span class="preprocessor"></span>
+<a name="l00451"></a>00451 
+<a name="l00452"></a>00452 <span class="comment">/*</span>
+<a name="l00453"></a>00453 <span class="comment"> * Pool Properties</span>
+<a name="l00454"></a>00454 <span class="comment"> */</span>
+<a name="l00455"></a>00455 <span class="comment"></span>
+<a name="l00456"></a>00456 <span class="comment">/**</span>
+<a name="l00457"></a>00457 <span class="comment"> * Set the function to be called when an allocation failure occurs.</span>
+<a name="l00458"></a>00458 <span class="comment"> * @remark If the program wants APR to exit on a memory allocation error,</span>
+<a name="l00459"></a>00459 <span class="comment"> *      then this function can be called to set the callback to use (for</span>
+<a name="l00460"></a>00460 <span class="comment"> *      performing cleanup and then exiting). If this function is not called,</span>
+<a name="l00461"></a>00461 <span class="comment"> *      then APR will return an error and expect the calling program to</span>
+<a name="l00462"></a>00462 <span class="comment"> *      deal with the error accordingly.</span>
+<a name="l00463"></a>00463 <span class="comment"> */</span>
+<a name="l00464"></a>00464 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#ga658b1f10dd13967eaa7c4156d4c2174">apr_pool_abort_set</a>(<a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a> abortfunc,
+<a name="l00465"></a>00465                                      <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00466"></a>00466 <span class="comment"></span>
+<a name="l00467"></a>00467 <span class="comment">/**</span>
+<a name="l00468"></a>00468 <span class="comment"> * Get the abort function associated with the specified pool.</span>
+<a name="l00469"></a>00469 <span class="comment"> * @param pool The pool for retrieving the abort function.</span>
+<a name="l00470"></a>00470 <span class="comment"> * @return The abort function for the given pool.</span>
 <a name="l00471"></a>00471 <span class="comment"> */</span>
-<a name="l00472"></a>00472 <span class="comment"></span>
-<a name="l00473"></a>00473 <span class="comment">/**</span>
-<a name="l00474"></a>00474 <span class="comment"> * Set the data associated with the current pool</span>
-<a name="l00475"></a>00475 <span class="comment"> * @param data The user data associated with the pool.</span>
-<a name="l00476"></a>00476 <span class="comment"> * @param key The key to use for association</span>
-<a name="l00477"></a>00477 <span class="comment"> * @param cleanup The cleanup program to use to cleanup the data (NULL if none)</span>
-<a name="l00478"></a>00478 <span class="comment"> * @param pool The current pool</span>
-<a name="l00479"></a>00479 <span class="comment"> * @warning The data to be attached to the pool should have a life span</span>
-<a name="l00480"></a>00480 <span class="comment"> *          at least as long as the pool it is being attached to.</span>
-<a name="l00481"></a>00481 <span class="comment"> *</span>
-<a name="l00482"></a>00482 <span class="comment"> *      Users of APR must take EXTREME care when choosing a key to</span>
-<a name="l00483"></a>00483 <span class="comment"> *      use for their data.  It is possible to accidentally overwrite</span>
-<a name="l00484"></a>00484 <span class="comment"> *      data by choosing a key that another part of the program is using.</span>
-<a name="l00485"></a>00485 <span class="comment"> *      Therefore it is advised that steps are taken to ensure that unique</span>
-<a name="l00486"></a>00486 <span class="comment"> *      keys are used for all of the userdata objects in a particular pool</span>
-<a name="l00487"></a>00487 <span class="comment"> *      (the same key in two different pools or a pool and one of its</span>
-<a name="l00488"></a>00488 <span class="comment"> *      subpools is okay) at all times.  Careful namespace prefixing of</span>
-<a name="l00489"></a>00489 <span class="comment"> *      key names is a typical way to help ensure this uniqueness.</span>
-<a name="l00490"></a>00490 <span class="comment"> *</span>
+<a name="l00472"></a>00472 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__pools.html#g0a1fe549a7c45b864c003ddf12115365">apr_abortfunc_t</a>) <a class="code" href="group__apr__pools.html#gf7610c30ef5f84a8742c0b3e63fdd7b0">apr_pool_abort_get</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00473"></a>00473 <span class="comment"></span>
+<a name="l00474"></a>00474 <span class="comment">/**</span>
+<a name="l00475"></a>00475 <span class="comment"> * Get the parent pool of the specified pool.</span>
+<a name="l00476"></a>00476 <span class="comment"> * @param pool The pool for retrieving the parent pool.</span>
+<a name="l00477"></a>00477 <span class="comment"> * @return The parent of the given pool.</span>
+<a name="l00478"></a>00478 <span class="comment"> */</span>
+<a name="l00479"></a>00479 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *) <a class="code" href="group__apr__pools.html#g94db31f40609b15b592ff47f989ca9ec">apr_pool_parent_get</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00480"></a>00480 <span class="comment"></span>
+<a name="l00481"></a>00481 <span class="comment">/**</span>
+<a name="l00482"></a>00482 <span class="comment"> * Determine if pool a is an ancestor of pool b.</span>
+<a name="l00483"></a>00483 <span class="comment"> * @param a The pool to search</span>
+<a name="l00484"></a>00484 <span class="comment"> * @param b The pool to search for</span>
+<a name="l00485"></a>00485 <span class="comment"> * @return True if a is an ancestor of b, NULL is considered an ancestor</span>
+<a name="l00486"></a>00486 <span class="comment"> *         of all pools.</span>
+<a name="l00487"></a>00487 <span class="comment"> * @remark if compiled with APR_POOL_DEBUG, this function will also</span>
+<a name="l00488"></a>00488 <span class="comment"> * return true if A is a pool which has been guaranteed by the caller</span>
+<a name="l00489"></a>00489 <span class="comment"> * (using apr_pool_join) to have a lifetime at least as long as some</span>
+<a name="l00490"></a>00490 <span class="comment"> * ancestor of pool B.</span>
 <a name="l00491"></a>00491 <span class="comment"> */</span>
-<a name="l00492"></a>00492 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g78d1aa2d9fa842d83eaffccb0f0c0c5c">apr_pool_userdata_set</a>(
-<a name="l00493"></a>00493     const <span class="keywordtype">void</span> *data,
-<a name="l00494"></a>00494     const <span class="keywordtype">char</span> *key,
-<a name="l00495"></a>00495     <a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> (*cleanup)(<span class="keywordtype">void</span> *),
-<a name="l00496"></a>00496     <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00497"></a>00497 <span class="comment"></span>
-<a name="l00498"></a>00498 <span class="comment">/**</span>
-<a name="l00499"></a>00499 <span class="comment"> * Set the data associated with the current pool</span>
-<a name="l00500"></a>00500 <span class="comment"> * @param data The user data associated with the pool.</span>
-<a name="l00501"></a>00501 <span class="comment"> * @param key The key to use for association</span>
-<a name="l00502"></a>00502 <span class="comment"> * @param cleanup The cleanup program to use to cleanup the data (NULL if none)</span>
-<a name="l00503"></a>00503 <span class="comment"> * @param pool The current pool</span>
-<a name="l00504"></a>00504 <span class="comment"> * @note same as apr_pool_userdata_set(), except that this version doesn't</span>
-<a name="l00505"></a>00505 <span class="comment"> *       make a copy of the key (this function is useful, for example, when</span>
-<a name="l00506"></a>00506 <span class="comment"> *       the key is a string literal)</span>
-<a name="l00507"></a>00507 <span class="comment"> * @warning This should NOT be used if the key could change addresses by</span>
-<a name="l00508"></a>00508 <span class="comment"> *       any means between the apr_pool_userdata_setn() call and a</span>
-<a name="l00509"></a>00509 <span class="comment"> *       subsequent apr_pool_userdata_get() on that key, such as if a</span>
-<a name="l00510"></a>00510 <span class="comment"> *       static string is used as a userdata key in a DSO and the DSO could</span>
-<a name="l00511"></a>00511 <span class="comment"> *       be unloaded and reloaded between the _setn() and the _get().  You</span>
-<a name="l00512"></a>00512 <span class="comment"> *       MUST use apr_pool_userdata_set() in such cases.</span>
-<a name="l00513"></a>00513 <span class="comment"> * @warning More generally, the key and the data to be attached to the</span>
-<a name="l00514"></a>00514 <span class="comment"> *       pool should have a life span at least as long as the pool itself.</span>
-<a name="l00515"></a>00515 <span class="comment"> *</span>
-<a name="l00516"></a>00516 <span class="comment"> */</span>
-<a name="l00517"></a>00517 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g435644c493dc5b10d80c4b99b8cd4589">apr_pool_userdata_setn</a>(
-<a name="l00518"></a>00518     const <span class="keywordtype">void</span> *data,
-<a name="l00519"></a>00519     const <span class="keywordtype">char</span> *key,
-<a name="l00520"></a>00520     <a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> (*cleanup)(<span class="keywordtype">void</span> *),
-<a name="l00521"></a>00521     <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00522"></a>00522 <span class="comment"></span>
-<a name="l00523"></a>00523 <span class="comment">/**</span>
-<a name="l00524"></a>00524 <span class="comment"> * Return the data associated with the current pool.</span>
-<a name="l00525"></a>00525 <span class="comment"> * @param data The user data associated with the pool.</span>
-<a name="l00526"></a>00526 <span class="comment"> * @param key The key for the data to retrieve</span>
-<a name="l00527"></a>00527 <span class="comment"> * @param pool The current pool.</span>
-<a name="l00528"></a>00528 <span class="comment"> */</span>
-<a name="l00529"></a>00529 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gf930f1fad2cf92a2432c0814c8a0b86f">apr_pool_userdata_get</a>(<span class="keywordtype">void</span> **data, const <span class="keywordtype">char</span> *key,
-<a name="l00530"></a>00530                                                 <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
-<a name="l00531"></a>00531 
-<a name="l00532"></a>00532 <span class="comment"></span>
-<a name="l00533"></a>00533 <span class="comment">/**</span>
-<a name="l00534"></a>00534 <span class="comment"> * @defgroup PoolCleanup  Pool Cleanup Functions</span>
-<a name="l00535"></a>00535 <span class="comment"> *</span>
-<a name="l00536"></a>00536 <span class="comment"> * Cleanups are performed in the reverse order they were registered.  That is:</span>
-<a name="l00537"></a>00537 <span class="comment"> * Last In, First Out.  A cleanup function can safely allocate memory from</span>
-<a name="l00538"></a>00538 <span class="comment"> * the pool that is being cleaned up. It can also safely register additional</span>
-<a name="l00539"></a>00539 <span class="comment"> * cleanups which will be run LIFO, directly after the current cleanup</span>
-<a name="l00540"></a>00540 <span class="comment"> * terminates.  Cleanups have to take caution in calling functions that</span>
-<a name="l00541"></a>00541 <span class="comment"> * create subpools. Subpools, created during cleanup will NOT automatically</span>
-<a name="l00542"></a>00542 <span class="comment"> * be cleaned up.  In other words, cleanups are to clean up after themselves.</span>
-<a name="l00543"></a>00543 <span class="comment"> *</span>
-<a name="l00544"></a>00544 <span class="comment"> * @{</span>
-<a name="l00545"></a>00545 <span class="comment"> */</span>
-<a name="l00546"></a>00546 <span class="comment"></span>
-<a name="l00547"></a>00547 <span class="comment">/**</span>
-<a name="l00548"></a>00548 <span class="comment"> * Register a function to be called when a pool is cleared or destroyed</span>
-<a name="l00549"></a>00549 <span class="comment"> * @param p The pool register the cleanup with</span>
-<a name="l00550"></a>00550 <span class="comment"> * @param data The data to pass to the cleanup function.</span>
-<a name="l00551"></a>00551 <span class="comment"> * @param plain_cleanup The function to call when the pool is cleared</span>
-<a name="l00552"></a>00552 <span class="comment"> *                      or destroyed</span>
-<a name="l00553"></a>00553 <span class="comment"> * @param child_cleanup The function to call when a child process is about</span>
-<a name="l00554"></a>00554 <span class="comment"> *                      to exec - this function is called in the child, obviously!</span>
-<a name="l00555"></a>00555 <span class="comment"> */</span>
-<a name="l00556"></a>00556 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group___pool_cleanup.html#g6bdb28224dfe08160cbe3ba6b22dcbd7">apr_pool_cleanup_register</a>(
-<a name="l00557"></a>00557     <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *p,
-<a name="l00558"></a>00558     const <span class="keywordtype">void</span> *data,
-<a name="l00559"></a>00559     <a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> (*plain_cleanup)(<span class="keywordtype">void</span> *),
-<a name="l00560"></a>00560     <a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> (*child_cleanup)(<span class="keywordtype">void</span> *));
-<a name="l00561"></a>00561 <span class="comment"></span>
-<a name="l00562"></a>00562 <span class="comment">/**</span>
-<a name="l00563"></a>00563 <span class="comment"> * Register a function to be called when a pool is cleared or destroyed.</span>
-<a name="l00564"></a>00564 <span class="comment"> *</span>
-<a name="l00565"></a>00565 <span class="comment"> * Unlike apr_pool_cleanup_register which register a cleanup</span>
-<a name="l00566"></a>00566 <span class="comment"> * that is called AFTER all subpools are destroyed this function register</span>
-<a name="l00567"></a>00567 <span class="comment"> * a function that will be called before any of the subpool is destoryed.</span>
+<a name="l00492"></a>00492 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">int</span>) <a class="code" href="group__apr__pools.html#g05d299f778659d1e0806140d8a7fea79">apr_pool_is_ancestor</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *a, <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *b);
+<a name="l00493"></a>00493 <span class="comment"></span>
+<a name="l00494"></a>00494 <span class="comment">/**</span>
+<a name="l00495"></a>00495 <span class="comment"> * Tag a pool (give it a name)</span>
+<a name="l00496"></a>00496 <span class="comment"> * @param pool The pool to tag</span>
+<a name="l00497"></a>00497 <span class="comment"> * @param tag  The tag</span>
+<a name="l00498"></a>00498 <span class="comment"> */</span>
+<a name="l00499"></a>00499 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<span class="keywordtype">void</span>) <a class="code" href="group__apr__pools.html#geaa872f7999740a60803e95429890518">apr_pool_tag</a>(<a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool, const <span class="keywordtype">char</span> *tag);
+<a name="l00500"></a>00500 
+<a name="l00501"></a>00501 
+<a name="l00502"></a>00502 <span class="comment">/*</span>
+<a name="l00503"></a>00503 <span class="comment"> * User data management</span>
+<a name="l00504"></a>00504 <span class="comment"> */</span>
+<a name="l00505"></a>00505 <span class="comment"></span>
+<a name="l00506"></a>00506 <span class="comment">/**</span>
+<a name="l00507"></a>00507 <span class="comment"> * Set the data associated with the current pool</span>
+<a name="l00508"></a>00508 <span class="comment"> * @param data The user data associated with the pool.</span>
+<a name="l00509"></a>00509 <span class="comment"> * @param key The key to use for association</span>
+<a name="l00510"></a>00510 <span class="comment"> * @param cleanup The cleanup program to use to cleanup the data (NULL if none)</span>
+<a name="l00511"></a>00511 <span class="comment"> * @param pool The current pool</span>
+<a name="l00512"></a>00512 <span class="comment"> * @warning The data to be attached to the pool should have a life span</span>
+<a name="l00513"></a>00513 <span class="comment"> *          at least as long as the pool it is being attached to.</span>
+<a name="l00514"></a>00514 <span class="comment"> *</span>
+<a name="l00515"></a>00515 <span class="comment"> *      Users of APR must take EXTREME care when choosing a key to</span>
+<a name="l00516"></a>00516 <span class="comment"> *      use for their data.  It is possible to accidentally overwrite</span>
+<a name="l00517"></a>00517 <span class="comment"> *      data by choosing a key that another part of the program is using.</span>
+<a name="l00518"></a>00518 <span class="comment"> *      Therefore it is advised that steps are taken to ensure that unique</span>
+<a name="l00519"></a>00519 <span class="comment"> *      keys are used for all of the userdata objects in a particular pool</span>
+<a name="l00520"></a>00520 <span class="comment"> *      (the same key in two different pools or a pool and one of its</span>
+<a name="l00521"></a>00521 <span class="comment"> *      subpools is okay) at all times.  Careful namespace prefixing of</span>
+<a name="l00522"></a>00522 <span class="comment"> *      key names is a typical way to help ensure this uniqueness.</span>
+<a name="l00523"></a>00523 <span class="comment"> *</span>
+<a name="l00524"></a>00524 <span class="comment"> */</span>
+<a name="l00525"></a>00525 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g78d1aa2d9fa842d83eaffccb0f0c0c5c">apr_pool_userdata_set</a>(
+<a name="l00526"></a>00526     const <span class="keywordtype">void</span> *data,
+<a name="l00527"></a>00527     const <span class="keywordtype">char</span> *key,
+<a name="l00528"></a>00528     <a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> (*cleanup)(<span class="keywordtype">void</span> *),
+<a name="l00529"></a>00529     <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00530"></a>00530 <span class="comment"></span>
+<a name="l00531"></a>00531 <span class="comment">/**</span>
+<a name="l00532"></a>00532 <span class="comment"> * Set the data associated with the current pool</span>
+<a name="l00533"></a>00533 <span class="comment"> * @param data The user data associated with the pool.</span>
+<a name="l00534"></a>00534 <span class="comment"> * @param key The key to use for association</span>
+<a name="l00535"></a>00535 <span class="comment"> * @param cleanup The cleanup program to use to cleanup the data (NULL if none)</span>
+<a name="l00536"></a>00536 <span class="comment"> * @param pool The current pool</span>
+<a name="l00537"></a>00537 <span class="comment"> * @note same as apr_pool_userdata_set(), except that this version doesn't</span>
+<a name="l00538"></a>00538 <span class="comment"> *       make a copy of the key (this function is useful, for example, when</span>
+<a name="l00539"></a>00539 <span class="comment"> *       the key is a string literal)</span>
+<a name="l00540"></a>00540 <span class="comment"> * @warning This should NOT be used if the key could change addresses by</span>
+<a name="l00541"></a>00541 <span class="comment"> *       any means between the apr_pool_userdata_setn() call and a</span>
+<a name="l00542"></a>00542 <span class="comment"> *       subsequent apr_pool_userdata_get() on that key, such as if a</span>
+<a name="l00543"></a>00543 <span class="comment"> *       static string is used as a userdata key in a DSO and the DSO could</span>
+<a name="l00544"></a>00544 <span class="comment"> *       be unloaded and reloaded between the _setn() and the _get().  You</span>
+<a name="l00545"></a>00545 <span class="comment"> *       MUST use apr_pool_userdata_set() in such cases.</span>
+<a name="l00546"></a>00546 <span class="comment"> * @warning More generally, the key and the data to be attached to the</span>
+<a name="l00547"></a>00547 <span class="comment"> *       pool should have a life span at least as long as the pool itself.</span>
+<a name="l00548"></a>00548 <span class="comment"> *</span>
+<a name="l00549"></a>00549 <span class="comment"> */</span>
+<a name="l00550"></a>00550 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#g435644c493dc5b10d80c4b99b8cd4589">apr_pool_userdata_setn</a>(
+<a name="l00551"></a>00551     const <span class="keywordtype">void</span> *data,
+<a name="l00552"></a>00552     const <span class="keywordtype">char</span> *key,
+<a name="l00553"></a>00553     <a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a> (*cleanup)(<span class="keywordtype">void</span> *),
+<a name="l00554"></a>00554     <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00555"></a>00555 <span class="comment"></span>
+<a name="l00556"></a>00556 <span class="comment">/**</span>
+<a name="l00557"></a>00557 <span class="comment"> * Return the data associated with the current pool.</span>
+<a name="l00558"></a>00558 <span class="comment"> * @param data The user data associated with the pool.</span>
+<a name="l00559"></a>00559 <span class="comment"> * @param key The key for the data to retrieve</span>
+<a name="l00560"></a>00560 <span class="comment"> * @param pool The current pool.</span>
+<a name="l00561"></a>00561 <span class="comment"> */</span>
+<a name="l00562"></a>00562 <a class="code" href="group__apr__platform.html#gd7b91b811a172bfa802603c2fb688f98">APR_DECLARE</a>(<a class="code" href="group__apr__errno.html#gf76ee4543247e9fb3f3546203e590a6c">apr_status_t</a>) <a class="code" href="group__apr__pools.html#gf930f1fad2cf92a2432c0814c8a0b86f">apr_pool_userdata_get</a>(<span class="keywordtype">void</span> **data, const <span class="keywordtype">char</span> *key,
+<a name="l00563"></a>00563                                                 <a class="code" href="group__apr__pools.html#gf137f28edcf9a086cd6bc36c20d7cdfb">apr_pool_t</a> *pool);
+<a name="l00564"></a>00564 
+<a name="l00565"></a>00565 <span class="comment"></span>
+<a name="l00566"></a>00566 <span class="comment">/**</span>

[... 386 lines stripped ...]


Mime
View raw message