blob: ec7144498d90602a3ed446093dc7acbe0ac9c5a6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/* value.c - routines for dealing with values */
/* $OpenLDAP$ */
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
*
* Copyright 1998-2022 The OpenLDAP Foundation.
* All rights reserved.
*
* 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 the file LICENSE in the
* top-level directory of the distribution or, alternatively, at
* <http://www.OpenLDAP.org/license.html>.
*/
/*
* Copyright (c) 1995 Regents of the University of Michigan.
* All rights reserved.
*
* Redistribution and use in source and binary forms are permitted
* provided that this notice is preserved and that due credit is given
* to the University of Michigan at Ann Arbor. The name of the University
* may not be used to endorse or promote products derived from this
* software without specific prior written permission. This software
* is provided ``as is'' without express or implied warranty.
*/
#include "portable.h"
#include "lload.h"
int
value_add_one( BerVarray *vals, struct berval *addval )
{
int n;
BerVarray v2;
if ( *vals == NULL ) {
*vals = (BerVarray)SLAP_MALLOC( 2 * sizeof(struct berval) );
if ( *vals == NULL ) {
Debug( LDAP_DEBUG_TRACE, "value_add_one: "
"SLAP_MALLOC failed.\n" );
return LBER_ERROR_MEMORY;
}
n = 0;
} else {
for ( n = 0; !BER_BVISNULL( &(*vals)[n] ); n++ ) {
; /* Empty */
}
*vals = (BerVarray)SLAP_REALLOC(
(char *)*vals, ( n + 2 ) * sizeof(struct berval) );
if ( *vals == NULL ) {
Debug( LDAP_DEBUG_TRACE, "value_add_one: "
"SLAP_MALLOC failed.\n" );
return LBER_ERROR_MEMORY;
}
}
v2 = &(*vals)[n];
ber_dupbv( v2, addval );
v2++;
BER_BVZERO( v2 );
return LDAP_SUCCESS;
}
|