]> git.sur5r.net Git - openldap/blob - libraries/liblber/lber-int.h
Added LDAP_LOG messages
[openldap] / libraries / liblber / lber-int.h
1 /* $OpenLDAP$ */
2 /*
3  * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved.
4  * COPYING RESTRICTIONS APPLY, see COPYRIGHT file
5  */
6 /* Portions
7  * Copyright (c) 1990 Regents of the University of Michigan.
8  * All rights reserved.
9  *
10  * Redistribution and use in source and binary forms are permitted
11  * provided that this notice is preserved and that due credit is given
12  * to the University of Michigan at Ann Arbor. The name of the University
13  * may not be used to endorse or promote products derived from this
14  * software without specific prior written permission. This software
15  * is provided ``as is'' without express or implied warranty.
16  */
17
18 #ifndef _LBER_INT_H
19 #define _LBER_INT_H
20
21 #include "lber.h"
22 #include "ldap_log.h"
23 #include "lber_pvt.h"
24 #include "ldap_queue.h"
25
26 LDAP_BEGIN_DECL
27
28 typedef void (*BER_LOG_FN)(FILE *file,
29         const char *subsys, int level, const char *fmt, ... );
30
31 LBER_V (BER_ERRNO_FN) ber_int_errno_fn;
32
33 struct lber_options {
34         short lbo_valid;
35         unsigned short          lbo_options;
36         int                     lbo_debug;
37         long            lbo_meminuse;
38 };
39
40 #ifdef NEW_LOGGING
41 #    ifdef LDAP_DEBUG
42 #        ifdef LDAP_LOG
43 #            undef LDAP_LOG
44 #        endif
45 #        define LDAP_LOG(a) ber_pvt_log_output a
46 #        define BER_DUMP(a) ber_output_dump a
47 #    else
48 #        define LDAP_LOG(a)
49 #        define BER_DUMP(a)
50 #    endif
51 #endif
52
53 LBER_F( int ) ber_pvt_log_output(
54         const char *subsystem,
55         int level,
56         const char *fmt, ... );
57
58 #define LBER_UNINITIALIZED              0x0
59 #define LBER_INITIALIZED                0x1
60 #define LBER_VALID_BERELEMENT   0x2
61 #define LBER_VALID_SOCKBUF              0x3
62
63 LBER_V (struct lber_options) ber_int_options;
64 #define ber_int_debug ber_int_options.lbo_debug
65
66 struct berelement {
67         struct          lber_options ber_opts;
68 #define ber_valid               ber_opts.lbo_valid
69 #define ber_options             ber_opts.lbo_options
70 #define ber_debug               ber_opts.lbo_debug
71
72         /* Do not change the order of these 3 fields! see ber_get_next */
73         ber_tag_t       ber_tag;
74         ber_len_t       ber_len;
75         ber_tag_t       ber_usertag;
76
77         char            *ber_buf;
78         char            *ber_ptr;
79         char            *ber_end;
80
81         struct seqorset *ber_sos;
82         char            *ber_rwptr;
83 };
84 #define LBER_VALID(ber) ((ber)->ber_valid==LBER_VALID_BERELEMENT)
85
86 #define ber_pvt_ber_remaining(ber)      ((ber)->ber_end - (ber)->ber_ptr)
87 #define ber_pvt_ber_total(ber)          ((ber)->ber_end - (ber)->ber_buf)
88 #define ber_pvt_ber_write(ber)          ((ber)->ber_ptr - (ber)->ber_buf)
89
90 struct sockbuf {
91         struct lber_options sb_opts;
92         Sockbuf_IO_Desc         *sb_iod;                /* I/O functions */
93 #define sb_valid                sb_opts.lbo_valid
94 #define sb_options              sb_opts.lbo_options
95 #define sb_debug                sb_opts.lbo_debug
96         ber_socket_t            sb_fd;
97         unsigned int            sb_trans_needs_read:1;
98         unsigned int            sb_trans_needs_write:1;
99         ber_len_t                       sb_max_incoming;
100 };
101
102 #define SOCKBUF_VALID( sb )     ( (sb)->sb_valid == LBER_VALID_SOCKBUF )
103
104 struct seqorset {
105         BerElement      *sos_ber;
106         ber_len_t       sos_clen;
107         ber_tag_t       sos_tag;
108         char            *sos_first;
109         char            *sos_ptr;
110         struct seqorset *sos_next;
111 };
112
113
114 /*
115  * io.c
116  */
117 LBER_F( int )
118 ber_realloc LDAP_P((
119         BerElement *ber,
120         ber_len_t len ));
121
122 /*
123  * bprint.c
124  */
125 #define ber_log_printf ber_pvt_log_printf
126
127 #ifdef NEW_LOGGING
128 LBER_F( int )
129 ber_output_dump LDAP_P((
130         const char *subsys,
131         int level,
132         BerElement *ber,
133         int inout ));
134 #endif
135
136 LBER_F( int )
137 ber_log_bprint LDAP_P((
138         int errlvl,
139         int loglvl,
140         const char *data,
141         ber_len_t len ));
142
143 LBER_F( int )
144 ber_log_dump LDAP_P((
145         int errlvl,
146         int loglvl,
147         BerElement *ber,
148         int inout ));
149
150 LBER_F( int )
151 ber_log_sos_dump LDAP_P((
152         int errlvl,
153         int loglvl,
154         Seqorset *sos ));
155
156 LBER_V (BER_LOG_FN) ber_int_log_proc;
157 LBER_V (FILE *) ber_pvt_err_file;
158
159 /* memory.c */
160         /* simple macros to realloc for now */
161 LBER_V (BerMemoryFunctions *)   ber_int_memory_fns;
162 LBER_F (char *) ber_strndup( LDAP_CONST char *, ber_len_t );
163 LBER_F (char *) ber_strndup__( LDAP_CONST char *, size_t );
164
165 #ifdef CSRIMALLOC
166 #define LBER_MALLOC                     malloc
167 #define LBER_CALLOC                     calloc
168 #define LBER_REALLOC            realloc
169 #define LBER_FREE                       free
170 #define LBER_VFREE                      ber_memvfree
171 #define LBER_STRDUP                     strdup
172 #define LBER_STRNDUP            ber_strndup__
173
174 #else
175 #define LBER_MALLOC(s)          ber_memalloc((s))
176 #define LBER_CALLOC(n,s)        ber_memcalloc((n),(s))
177 #define LBER_REALLOC(p,s)       ber_memrealloc((p),(s))
178 #define LBER_FREE(p)            ber_memfree((p))        
179 #define LBER_VFREE(v)           ber_memvfree((void**)(v))
180 #define LBER_STRDUP(s)          ber_strdup((s))
181 #define LBER_STRNDUP(s,l)       ber_strndup((s),(l))
182 #endif
183
184 /* sockbuf.c */
185
186 LBER_F( int )
187 ber_int_sb_init LDAP_P(( Sockbuf *sb ));
188
189 LBER_F( int )
190 ber_int_sb_close LDAP_P(( Sockbuf *sb ));
191
192 LBER_F( int )
193 ber_int_sb_destroy LDAP_P(( Sockbuf *sb ));
194
195 LBER_F( ber_slen_t )
196 ber_int_sb_read LDAP_P(( Sockbuf *sb, void *buf, ber_len_t len ));
197
198 LBER_F( ber_slen_t )
199 ber_int_sb_write LDAP_P(( Sockbuf *sb, void *buf, ber_len_t len ));
200
201 LDAP_END_DECL
202
203 #endif /* _LBER_INT_H */