+/* $OpenLDAP$ */
/*
* Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved.
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
#include <ac/stdlib.h>
#include <ac/string.h>
-#undef LDAP_F_PRE
-#define LDAP_F_PRE LDAP_F_EXPORT
-
#include "lber-int.h"
+extern void * ber_pvt_err_file; /* bprint.c */
+
struct lber_options ber_int_options = {
LBER_UNINITIALIZED, 0, 0 };
int
ber_get_option(
- LDAP_CONST void *item,
+ void *item,
int option,
void *outvalue)
{
if(outvalue == NULL) {
/* no place to get to */
+ ber_errno = LBER_ERROR_PARAM;
return LBER_OPT_ERROR;
}
return LBER_OPT_SUCCESS;
}
+ ber_errno = LBER_ERROR_PARAM;
return LBER_OPT_ERROR;
}
* (int *) outvalue = ber->ber_debug;
return LBER_OPT_SUCCESS;
+ case LBER_OPT_BER_REMAINING_BYTES:
+ *((ber_len_t *) outvalue) = ber->ber_end - ber->ber_ptr;
+ return LBER_OPT_SUCCESS;
+
+ case LBER_OPT_BER_TOTAL_BYTES:
+ *((ber_len_t *) outvalue) = ber->ber_end - ber->ber_buf;
+ return LBER_OPT_SUCCESS;
+
+ case LBER_OPT_BER_BYTES_TO_WRITE:
+ *((ber_len_t *) outvalue) = ber->ber_ptr - ber->ber_buf;
+ return LBER_OPT_SUCCESS;
+
default:
/* bad param */
+ ber_errno = LBER_ERROR_PARAM;
break;
}
&& ( option == LBER_OPT_MEMORY_FNS )
&& ( invalue != NULL ))
{
- BerMemoryFunctions *f = (BerMemoryFunctions *) invalue;
+ 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;
}
(*(f->bmf_malloc))(sizeof(BerMemoryFunctions));
if ( ber_int_memory_fns == NULL ) {
+ ber_errno = LBER_ERROR_MEMORY;
return LBER_OPT_ERROR;
}
if(invalue == NULL) {
/* no place to set from */
+ ber_errno = LBER_ERROR_PARAM;
return LBER_OPT_ERROR;
}
if(item == NULL) {
if(option == LBER_OPT_BER_DEBUG) {
- ber_int_debug = * (int *) invalue;
+ ber_int_debug = * (const int *) invalue;
return LBER_OPT_SUCCESS;
} else if(option == LBER_OPT_LOG_PRINT_FN) {
ber_pvt_log_print = (BER_LOG_PRINT_FN) invalue;
return LBER_OPT_SUCCESS;
+ } else if(option == LBER_OPT_LOG_PRINT_FILE) {
+ ber_pvt_err_file = (void *) invalue;
+ return LBER_OPT_SUCCESS;
}
+ ber_errno = LBER_ERROR_PARAM;
return LBER_OPT_ERROR;
}
switch(option) {
case LBER_OPT_BER_OPTIONS:
assert( BER_VALID( ber ) );
- ber->ber_options = * (int *) invalue;
+ ber->ber_options = * (const int *) invalue;
return LBER_OPT_SUCCESS;
case LBER_OPT_BER_DEBUG:
assert( BER_VALID( ber ) );
- ber->ber_debug = * (int *) invalue;
+ ber->ber_debug = * (const int *) invalue;
+ return LBER_OPT_SUCCESS;
+
+ case LBER_OPT_BER_REMAINING_BYTES:
+ ber->ber_end = &ber->ber_ptr[* (const ber_len_t *) invalue];
+ return LBER_OPT_SUCCESS;
+
+ case LBER_OPT_BER_TOTAL_BYTES:
+ ber->ber_end = &ber->ber_buf[* (const ber_len_t *) invalue];
+ return LBER_OPT_SUCCESS;
+
+ case LBER_OPT_BER_BYTES_TO_WRITE:
+ ber->ber_ptr = &ber->ber_buf[* (const ber_len_t *) invalue];
return LBER_OPT_SUCCESS;
default:
/* bad param */
+ ber_errno = LBER_ERROR_PARAM;
break;
}