Skip to content

Commit

Permalink
Add empty stubs for APR pool functions, that are
Browse files Browse the repository at this point in the history
only needed when APR_POOL_DEBUG is defined,
but can be aor should be called from app code.

Providing stubs allows the app code to stay the
same when running with or without debugging APR
lib (no need for app recompilation).

Backport of r1863217 from trunk resp. r1863234 from 1.7.x.


git-svn-id: https://svn.apache.org/repos/asf/apr/apr/branches/1.6.x@1863235 13f79535-47bb-0310-9956-ffa450edef68
  • Loading branch information
Rainer Jung committed Jul 17, 2019
1 parent c34a31a commit 059434d
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 17 deletions.
19 changes: 3 additions & 16 deletions include/apr_pools.h
Original file line number Diff line number Diff line change
Expand Up @@ -754,11 +754,12 @@ APR_DECLARE(void) apr_pool_cleanup_for_exec(void);
* In this case the caller must call apr_pool_join() to indicate this
* guarantee to the APR_POOL_DEBUG code.
*
* These functions are only implemented when #APR_POOL_DEBUG is set.
* These functions have an empty implementation if APR is compiled
* with #APR_POOL_DEBUG not set.
*
* @{
*/
#if APR_POOL_DEBUG || defined(DOXYGEN)

/**
* Guarantee that a subpool has the same lifetime as the parent.
* @param p The parent pool
Expand Down Expand Up @@ -792,20 +793,6 @@ APR_DECLARE(void) apr_pool_lock(apr_pool_t *pool, int flag);

/* @} */

#else /* APR_POOL_DEBUG or DOXYGEN */

#ifdef apr_pool_join
#undef apr_pool_join
#endif
#define apr_pool_join(a,b)

#ifdef apr_pool_lock
#undef apr_pool_lock
#endif
#define apr_pool_lock(pool, lock)

#endif /* APR_POOL_DEBUG or DOXYGEN */

/** @} */

#ifdef __cplusplus
Expand Down
25 changes: 24 additions & 1 deletion memory/unix/apr_pools.c
Original file line number Diff line number Diff line change
Expand Up @@ -2834,13 +2834,13 @@ static void free_proc_chain(struct process_chain *procs)
}
}

#if !APR_POOL_DEBUG

/*
* Pool creation/destruction stubs, for people who are running
* mixed release/debug enviroments.
*/

#if !APR_POOL_DEBUG
APR_DECLARE(void *) apr_palloc_debug(apr_pool_t *pool, apr_size_t size,
const char *file_line)
{
Expand Down Expand Up @@ -2890,6 +2890,29 @@ APR_DECLARE(apr_status_t) apr_pool_create_unmanaged_ex_debug(apr_pool_t **newpoo
return apr_pool_create_unmanaged_ex(newpool, abort_fn, allocator);
}

/*
* Other stubs, for people who are running
* mixed release/debug enviroments.
*/

APR_DECLARE(void) apr_pool_join(apr_pool_t *p, apr_pool_t *sub)
{
}

APR_DECLARE(apr_pool_t *) apr_pool_find(const void *mem)
{
return NULL;
}

APR_DECLARE(apr_size_t) apr_pool_num_bytes(apr_pool_t *pool, int recurse)
{
return 0;
}

APR_DECLARE(void) apr_pool_lock(apr_pool_t *pool, int flag)
{
}

#else /* APR_POOL_DEBUG */

#undef apr_palloc
Expand Down

0 comments on commit 059434d

Please sign in to comment.