X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=servers%2Fslapd%2Fch_malloc.c;h=c9af173946e0f06c03a56f9692ba91f180de5678;hb=7666bb7482e788e478fbb506fb25645ae06f86a9;hp=27b7cca7696592b287f1f682cd2cb3b55dc7819d;hpb=9c3ed0310bc6de304f58f74daf967e6d405a19a5;p=openldap diff --git a/servers/slapd/ch_malloc.c b/servers/slapd/ch_malloc.c index 27b7cca769..c9af173946 100644 --- a/servers/slapd/ch_malloc.c +++ b/servers/slapd/ch_malloc.c @@ -1,9 +1,12 @@ /* ch_malloc.c - malloc routines that test returns from malloc and friends */ +/* $OpenLDAP$ */ /* - * Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved. + * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ +#define CH_FREE 1 + #include "portable.h" #include @@ -15,6 +18,8 @@ #include "slap.h" +#ifndef CSRIMALLOC + void * ch_malloc( ber_len_t size @@ -23,9 +28,15 @@ ch_malloc( void *new; if ( (new = (void *) ber_memalloc( size )) == NULL ) { +#ifdef NEW_LOGGING + LDAP_LOG( OPERATION, ERR, + "ch_malloc: allocation of %lu bytes failed\n", (long)size, 0,0 ); +#else Debug( LDAP_DEBUG_ANY, "ch_malloc of %lu bytes failed\n", (long) size, 0, 0 ); - exit( EXIT_SUCCESS ); +#endif + assert( 0 ); + exit( EXIT_FAILURE ); } return( new ); @@ -48,9 +59,15 @@ ch_realloc( } if ( (new = (void *) ber_memrealloc( block, size )) == NULL ) { +#ifdef NEW_LOGGING + LDAP_LOG( OPERATION, ERR, + "ch_realloc: reallocation of %lu bytes failed\n", (long)size, 0,0 ); +#else Debug( LDAP_DEBUG_ANY, "ch_realloc of %lu bytes failed\n", (long) size, 0, 0 ); - exit( EXIT_SUCCESS ); +#endif + assert( 0 ); + exit( EXIT_FAILURE ); } return( new ); @@ -65,8 +82,15 @@ ch_calloc( void *new; if ( (new = (void *) ber_memcalloc( nelem, size )) == NULL ) { +#ifdef NEW_LOGGING + LDAP_LOG( OPERATION, ERR, + "ch_calloc: allocation of %lu elements of %lu bytes faild\n", + (long)nelem, (long)size, 0 ); +#else Debug( LDAP_DEBUG_ANY, "ch_calloc of %lu elems of %lu bytes failed\n", (long) nelem, (long) size, 0 ); +#endif + assert( 0 ); exit( EXIT_FAILURE ); } @@ -81,7 +105,13 @@ ch_strdup( char *new; if ( (new = ber_strdup( string )) == NULL ) { +#ifdef NEW_LOGGING + LDAP_LOG( OPERATION, ERR, + "chr_strdup: duplication of \"%s\" failed\n", string, 0, 0 ); +#else Debug( LDAP_DEBUG_ANY, "ch_strdup(%s) failed\n", string, 0, 0 ); +#endif + assert( 0 ); exit( EXIT_FAILURE ); } @@ -93,3 +123,5 @@ ch_free( void *ptr ) { ber_memfree( ptr ); } + +#endif