X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Flber.h;h=3017d56181602970f5b11488d56c9e5f2276fdb1;hb=b464bc204ffdd2489fa5417b821755dcbaeb968b;hp=f45b59ab13f37e3a3b52e437731722404788c88b;hpb=25a9f7427ddc1b584a721ceb0e12690a96d3639e;p=openldap diff --git a/include/lber.h b/include/lber.h index f45b59ab13..3017d56181 100644 --- a/include/lber.h +++ b/include/lber.h @@ -1,15 +1,18 @@ /* $OpenLDAP$ */ -/* - * Copyright 1998-2000 The OpenLDAP Foundation, Redwood City, California, USA +/* This work is part of OpenLDAP Software . + * + * Copyright 1998-2006 The OpenLDAP Foundation. * All rights reserved. * - * Redistribution and use in source and binary forms are permitted only - * as authorized by the OpenLDAP Public License. A copy of this - * license is available at http://www.OpenLDAP.org/license.html or - * in file LICENSE in the top-level directory of the distribution. + * Redistribution and use in source and binary forms, with or without + * modification, are permitted only as authorized by the OpenLDAP + * Public License. + * + * A copy of this license is available in file LICENSE in the + * top-level directory of the distribution or, alternatively, at + * . */ -/* Portions - * Copyright (c) 1990 Regents of the University of Michigan. +/* Portions Copyright (c) 1990 Regents of the University of Michigan. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -24,6 +27,7 @@ #define _LBER_H #include +#include LDAP_BEGIN_DECL @@ -82,7 +86,6 @@ LDAP_BEGIN_DECL /* LBER BerElement options */ #define LBER_USE_DER 0x01 -#define LBER_USE_INDEFINITE_LEN 0x02 /* get/set options for BerElement */ #define LBER_OPT_BER_OPTIONS 0x01 @@ -90,6 +93,7 @@ LDAP_BEGIN_DECL #define LBER_OPT_BER_REMAINING_BYTES 0x03 #define LBER_OPT_BER_TOTAL_BYTES 0x04 #define LBER_OPT_BER_BYTES_TO_WRITE 0x05 +#define LBER_OPT_BER_MEMCTX 0x06 #define LBER_OPT_DEBUG_LEVEL LBER_OPT_BER_DEBUG #define LBER_OPT_REMAINING_BYTES LBER_OPT_BER_REMAINING_BYTES @@ -103,24 +107,25 @@ LDAP_BEGIN_DECL /* get/set Memory Debug options */ #define LBER_OPT_MEMORY_INUSE 0x8005 /* for memory debugging */ +#define LBER_OPT_LOG_PROC 0x8006 /* for external logging function */ typedef int* (*BER_ERRNO_FN) LDAP_P(( void )); typedef void (*BER_LOG_PRINT_FN) LDAP_P(( LDAP_CONST char *buf )); -typedef void* (*BER_MEMALLOC_FN) LDAP_P(( ber_len_t size )); -typedef void* (*BER_MEMCALLOC_FN) LDAP_P(( ber_len_t n, ber_len_t size )); -typedef void* (*BER_MEMREALLOC_FN) LDAP_P(( void *p, ber_len_t size )); -typedef void (*BER_MEMFREE_FN) LDAP_P(( void *p )); +typedef void* (BER_MEMALLOC_FN) LDAP_P(( ber_len_t size, void *ctx )); +typedef void* (BER_MEMCALLOC_FN) LDAP_P(( ber_len_t n, ber_len_t size, void *ctx )); +typedef void* (BER_MEMREALLOC_FN) LDAP_P(( void *p, ber_len_t size, void *ctx )); +typedef void (BER_MEMFREE_FN) LDAP_P(( void *p, void *ctx )); typedef struct lber_memory_fns { - BER_MEMALLOC_FN bmf_malloc; - BER_MEMCALLOC_FN bmf_calloc; - BER_MEMREALLOC_FN bmf_realloc; - BER_MEMFREE_FN bmf_free; + BER_MEMALLOC_FN *bmf_malloc; + BER_MEMCALLOC_FN *bmf_calloc; + BER_MEMREALLOC_FN *bmf_realloc; + BER_MEMFREE_FN *bmf_free; } BerMemoryFunctions; -/* LBER Sockbuf_IO options */ +/* LBER Sockbuf_IO options */ #define LBER_SB_OPT_GET_FD 1 #define LBER_SB_OPT_SET_FD 2 #define LBER_SB_OPT_HAS_IO 3 @@ -131,8 +136,10 @@ typedef struct lber_memory_fns { #define LBER_SB_OPT_DRAIN 10 #define LBER_SB_OPT_NEEDS_READ 11 #define LBER_SB_OPT_NEEDS_WRITE 12 +#define LBER_SB_OPT_GET_MAX_INCOMING 13 +#define LBER_SB_OPT_SET_MAX_INCOMING 14 /* Largest option used by the library */ -#define LBER_SB_OPT_OPT_MAX 12 +#define LBER_SB_OPT_OPT_MAX 14 /* LBER IO operations stacking levels */ #define LBER_SBIOD_LEVEL_PROVIDER 10 @@ -145,7 +152,8 @@ typedef struct lber_memory_fns { #define LBER_OPT_SOCKBUF_DEBUG 0x1002 /* on/off values */ -#define LBER_OPT_ON ((void *) 1) +LBER_V( char ) ber_pvt_opt_on; +#define LBER_OPT_ON ((void *) &ber_pvt_opt_on) #define LBER_OPT_OFF ((void *) 0) #define LBER_OPT_SUCCESS (0) @@ -171,12 +179,12 @@ struct sockbuf_io { int (*sbi_setup)( Sockbuf_IO_Desc *sbiod, void *arg ); int (*sbi_remove)( Sockbuf_IO_Desc *sbiod ); int (*sbi_ctrl)( Sockbuf_IO_Desc *sbiod, int opt, void *arg); - + ber_slen_t (*sbi_read)( Sockbuf_IO_Desc *sbiod, void *buf, ber_len_t len ); ber_slen_t (*sbi_write)( Sockbuf_IO_Desc *sbiod, void *buf, ber_len_t len ); - + int (*sbi_close)( Sockbuf_IO_Desc *sbiod ); }; @@ -198,6 +206,8 @@ typedef struct berval { char *bv_val; } BerValue; +typedef BerValue *BerVarray; /* To distinguish from a single bv */ + /* this should be moved to lber-int.h */ /* @@ -219,7 +229,6 @@ LBER_F( void ) ber_sos_dump LDAP_P(( Seqorset *sos )); - /* * in decode.c: */ @@ -258,6 +267,12 @@ ber_get_stringb LDAP_P(( char *buf, ber_len_t *len )); +LBER_F( ber_tag_t ) +ber_get_stringbv LDAP_P(( + BerElement *ber, + struct berval *bv, + int alloc )); + LBER_F( ber_tag_t ) ber_get_stringa LDAP_P(( BerElement *ber, @@ -296,7 +311,7 @@ ber_next_element LDAP_P(( LDAP_CONST char *last )); LBER_F( ber_tag_t ) -ber_scanf LDAP_P(( +ber_scanf LDAP_P(( BerElement *ber, LDAP_CONST char *fmt, ... )); @@ -330,7 +345,7 @@ ber_put_ostring LDAP_P(( LBER_F( int ) ber_put_berval LDAP_P(( BerElement *ber, - LDAP_CONST struct berval *bv, + struct berval *bv, ber_tag_t tag )); LBER_F( int ) @@ -404,6 +419,9 @@ ber_free LDAP_P(( BerElement *ber, int freebuf )); +LBER_F( void ) +ber_free_buf LDAP_P(( BerElement *ber )); + LBER_F( int ) ber_flush LDAP_P(( Sockbuf *sb, @@ -431,7 +449,13 @@ ber_get_next LDAP_P(( BerElement *ber )); LBER_F( void ) -ber_init_w_nullc LDAP_P(( +ber_init2 LDAP_P(( + BerElement *ber, + struct berval *bv, + int options )); + +LBER_F( void ) +ber_init_w_nullc LDAP_P(( /* DEPRECATED */ BerElement *ber, int options )); @@ -449,6 +473,16 @@ ber_flatten LDAP_P(( BerElement *ber, struct berval **bvPtr )); +LBER_F( int ) +ber_flatten2 LDAP_P(( + BerElement *ber, + struct berval *bv, + int alloc )); + +LBER_F( int ) +ber_remaining LDAP_P(( + BerElement *ber )); + /* * LBER ber accessor functions */ @@ -496,10 +530,11 @@ ber_sockbuf_ctrl LDAP_P(( int opt, void *arg )); -LBER_F( Sockbuf_IO ) ber_sockbuf_io_tcp; -LBER_F( Sockbuf_IO ) ber_sockbuf_io_readahead; -LBER_F( Sockbuf_IO ) ber_sockbuf_io_fd; -LBER_F( Sockbuf_IO ) ber_sockbuf_io_debug; +LBER_V( Sockbuf_IO ) ber_sockbuf_io_tcp; +LBER_V( Sockbuf_IO ) ber_sockbuf_io_readahead; +LBER_V( Sockbuf_IO ) ber_sockbuf_io_fd; +LBER_V( Sockbuf_IO ) ber_sockbuf_io_debug; +LBER_V( Sockbuf_IO ) ber_sockbuf_io_udp; /* * LBER memory.c @@ -539,22 +574,44 @@ ber_bvecadd LDAP_P(( struct berval ***bvec, struct berval *bv )); +LBER_F( struct berval * ) +ber_dupbv LDAP_P(( + struct berval *dst, struct berval *src )); + LBER_F( struct berval * ) ber_bvdup LDAP_P(( - LDAP_CONST struct berval *bv )); + struct berval *src )); LBER_F( struct berval * ) -ber_bvstr LDAP_P(( - LDAP_CONST char * )); +ber_mem2bv LDAP_P(( + LDAP_CONST char *, ber_len_t len, int duplicate, struct berval *bv)); LBER_F( struct berval * ) -ber_bvstrdup LDAP_P(( - LDAP_CONST char * )); +ber_str2bv LDAP_P(( + LDAP_CONST char *, ber_len_t len, int duplicate, struct berval *bv)); + +#define ber_bvstr(a) ((ber_str2bv)((a), 0, 0, NULL)) +#define ber_bvstrdup(a) ((ber_str2bv)((a), 0, 1, NULL)) LBER_F( char * ) ber_strdup LDAP_P(( LDAP_CONST char * )); +LBER_F( struct berval * ) +ber_bvreplace LDAP_P(( + struct berval *dst, LDAP_CONST struct berval *src )); + +LBER_F( void ) +ber_bvarray_free LDAP_P(( BerVarray p )); + +LBER_F( int ) +ber_bvarray_add LDAP_P(( BerVarray *p, BerValue *bv )); + +#define ber_bvcmp(v1,v2) \ + ((v1)->bv_len < (v2)->bv_len \ + ? -1 : ((v1)->bv_len > (v2)->bv_len \ + ? 1 : memcmp((v1)->bv_val, (v2)->bv_val, (v1)->bv_len) )) + /* * error.c */