X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=libraries%2Fliblber%2Foptions.c;h=42a69acb6ce3b2db7e3a7eb2945db3557cb79ea2;hb=2dd578221b3dbaf7ba2308b63c3cc46154323cae;hp=39f58a6bef26be2873429765181752c100702214;hpb=aa0b0f642fe69252559843af887477fa8982ae3b;p=openldap diff --git a/libraries/liblber/options.c b/libraries/liblber/options.c index 39f58a6bef..42a69acb6c 100644 --- a/libraries/liblber/options.c +++ b/libraries/liblber/options.c @@ -1,7 +1,7 @@ /* $OpenLDAP$ */ /* This work is part of OpenLDAP Software . * - * Copyright 1998-2005 The OpenLDAP Foundation. + * Copyright 1998-2011 The OpenLDAP Foundation. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -23,7 +23,7 @@ char ber_pvt_opt_on; /* used to get a non-NULL address for *_OPT_ON */ struct lber_options ber_int_options = { - LBER_UNINITIALIZED, 0, 0, 0 }; + LBER_UNINITIALIZED, 0, 0 }; static BerMemoryFunctions ber_int_memory_fns_datum; @@ -36,8 +36,6 @@ ber_get_option( const BerElement *ber; const Sockbuf *sb; - ber_int_options.lbo_valid = LBER_INITIALIZED; - if(outvalue == NULL) { /* no place to get to */ ber_errno = LBER_ERROR_PARAM; @@ -59,7 +57,7 @@ ber_get_option( * The counter is not accurate for multithreaded ldap applications. */ #ifdef LDAP_MEMORY_DEBUG - * (int *) outvalue = ber_int_options.lbo_meminuse; + * (int *) outvalue = ber_int_meminuse; return LBER_OPT_SUCCESS; #else return LBER_OPT_ERROR; @@ -126,31 +124,6 @@ ber_set_option( BerElement *ber; Sockbuf *sb; - if( (ber_int_options.lbo_valid == LBER_UNINITIALIZED) - && ( ber_int_memory_fns == NULL ) - && ( option == LBER_OPT_MEMORY_FNS ) - && ( invalue != NULL ) ) - { - const BerMemoryFunctions *f = - (const BerMemoryFunctions *) invalue; - /* make sure all functions are provided */ - if(!( f->bmf_malloc && f->bmf_calloc - && f->bmf_realloc && f->bmf_free )) - { - ber_errno = LBER_ERROR_PARAM; - return LBER_OPT_ERROR; - } - - ber_int_memory_fns = &ber_int_memory_fns_datum; - - AC_MEMCPY(ber_int_memory_fns, f, sizeof(BerMemoryFunctions)); - - ber_int_options.lbo_valid = LBER_INITIALIZED; - return LBER_OPT_SUCCESS; - } - - ber_int_options.lbo_valid = LBER_INITIALIZED; - if(invalue == NULL) { /* no place to set from */ ber_errno = LBER_ERROR_PARAM; @@ -180,11 +153,33 @@ ber_set_option( * The counter is not accurate for multithreaded applications. */ #ifdef LDAP_MEMORY_DEBUG - ber_int_options.lbo_meminuse = * (int *) invalue; + ber_int_meminuse = * (int *) invalue; return LBER_OPT_SUCCESS; #else return LBER_OPT_ERROR; #endif + case LBER_OPT_MEMORY_FNS: + if ( ber_int_memory_fns == NULL ) + { + const BerMemoryFunctions *f = + (const BerMemoryFunctions *) invalue; + /* make sure all functions are provided */ + if(!( f->bmf_malloc && f->bmf_calloc + && f->bmf_realloc && f->bmf_free )) + { + ber_errno = LBER_ERROR_PARAM; + return LBER_OPT_ERROR; + } + + ber_int_memory_fns = &ber_int_memory_fns_datum; + + AC_MEMCPY(ber_int_memory_fns, f, + sizeof(BerMemoryFunctions)); + + return LBER_OPT_SUCCESS; + } + break; + case LBER_OPT_LOG_PROC: ber_int_log_proc = (BER_LOG_FN)invalue; return LBER_OPT_SUCCESS;