1998-08-09 08:43:13 +08:00
|
|
|
/* charray.c - routines for dealing with char * arrays */
|
1999-09-09 03:06:24 +08:00
|
|
|
/* $OpenLDAP$ */
|
1999-08-07 07:07:46 +08:00
|
|
|
/*
|
2000-05-13 10:47:56 +08:00
|
|
|
* Copyright 1998-2000 The OpenLDAP Foundation, All Rights Reserved.
|
1999-08-07 07:07:46 +08:00
|
|
|
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
|
|
|
|
*/
|
1998-08-09 08:43:13 +08:00
|
|
|
|
1998-10-25 09:41:42 +08:00
|
|
|
#include "portable.h"
|
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
#include <stdio.h>
|
1998-10-25 09:41:42 +08:00
|
|
|
|
|
|
|
#include <ac/string.h>
|
|
|
|
#include <ac/socket.h>
|
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
#include "slap.h"
|
|
|
|
|
|
|
|
void
|
|
|
|
charray_add(
|
|
|
|
char ***a,
|
1999-08-21 03:00:44 +08:00
|
|
|
const char *s
|
1998-08-09 08:43:13 +08:00
|
|
|
)
|
|
|
|
{
|
|
|
|
int n;
|
|
|
|
|
|
|
|
if ( *a == NULL ) {
|
|
|
|
*a = (char **) ch_malloc( 2 * sizeof(char *) );
|
|
|
|
n = 0;
|
|
|
|
} else {
|
|
|
|
for ( n = 0; *a != NULL && (*a)[n] != NULL; n++ ) {
|
|
|
|
; /* NULL */
|
|
|
|
}
|
|
|
|
|
|
|
|
*a = (char **) ch_realloc( (char *) *a,
|
|
|
|
(n + 2) * sizeof(char *) );
|
|
|
|
}
|
|
|
|
|
1998-12-29 07:43:04 +08:00
|
|
|
(*a)[n++] = ch_strdup(s);
|
1998-08-09 08:43:13 +08:00
|
|
|
(*a)[n] = NULL;
|
|
|
|
}
|
|
|
|
|
2001-07-06 20:20:26 +08:00
|
|
|
void
|
|
|
|
charray_add_n(
|
|
|
|
char ***a,
|
|
|
|
const char *s,
|
|
|
|
int l
|
|
|
|
)
|
|
|
|
{
|
|
|
|
int n;
|
|
|
|
|
|
|
|
if ( *a == NULL ) {
|
|
|
|
*a = (char **) ch_malloc( 2 * sizeof(char *) );
|
|
|
|
n = 0;
|
|
|
|
} else {
|
|
|
|
for ( n = 0; *a != NULL && (*a)[n] != NULL; n++ ) {
|
|
|
|
; /* NULL */
|
|
|
|
}
|
|
|
|
|
|
|
|
*a = (char **) ch_realloc( (char *) *a,
|
|
|
|
(n + 2) * sizeof(char *) );
|
|
|
|
}
|
|
|
|
|
|
|
|
(*a)[n] = (char *) ch_malloc( ( l + 1 ) * sizeof( char ) );
|
|
|
|
strncpy( (*a)[n], s, l );
|
|
|
|
(*a)[n][l] = '\0';
|
|
|
|
(*a)[++n] = NULL;
|
|
|
|
}
|
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
void
|
|
|
|
charray_merge(
|
|
|
|
char ***a,
|
1999-08-21 03:50:11 +08:00
|
|
|
char **s
|
1998-08-09 08:43:13 +08:00
|
|
|
)
|
|
|
|
{
|
|
|
|
int i, n, nn;
|
|
|
|
|
|
|
|
for ( n = 0; *a != NULL && (*a)[n] != NULL; n++ ) {
|
|
|
|
; /* NULL */
|
|
|
|
}
|
|
|
|
for ( nn = 0; s[nn] != NULL; nn++ ) {
|
|
|
|
; /* NULL */
|
|
|
|
}
|
|
|
|
|
|
|
|
*a = (char **) ch_realloc( (char *) *a, (n + nn + 1) * sizeof(char *) );
|
|
|
|
|
|
|
|
for ( i = 0; i < nn; i++ ) {
|
1998-12-29 07:43:04 +08:00
|
|
|
(*a)[n + i] = ch_strdup(s[i]);
|
1998-08-09 08:43:13 +08:00
|
|
|
}
|
|
|
|
(*a)[n + nn] = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
charray_free( char **array )
|
|
|
|
{
|
|
|
|
char **a;
|
|
|
|
|
|
|
|
if ( array == NULL ) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
for ( a = array; *a != NULL; a++ ) {
|
|
|
|
if ( *a != NULL ) {
|
|
|
|
free( *a );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
free( (char *) array );
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
charray_inlist(
|
1999-08-21 03:50:11 +08:00
|
|
|
char **a,
|
1999-08-21 03:00:44 +08:00
|
|
|
const char *s
|
1998-08-09 08:43:13 +08:00
|
|
|
)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
2000-06-05 11:10:46 +08:00
|
|
|
if( a == NULL ) return 0;
|
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
for ( i = 0; a[i] != NULL; i++ ) {
|
|
|
|
if ( strcasecmp( s, a[i] ) == 0 ) {
|
|
|
|
return( 1 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return( 0 );
|
|
|
|
}
|
|
|
|
|
2001-12-26 16:17:44 +08:00
|
|
|
int
|
|
|
|
bvec_inlist(
|
|
|
|
struct berval **a,
|
|
|
|
struct berval *s
|
|
|
|
)
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if( a == NULL ) return 0;
|
|
|
|
|
|
|
|
for ( i = 0; a[i] != NULL; i++ ) {
|
|
|
|
if ( a[i]->bv_len != s->bv_len) continue;
|
|
|
|
if ( strcasecmp( s->bv_val, a[i]->bv_val ) == 0 ) {
|
|
|
|
return( 1 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return( 0 );
|
|
|
|
}
|
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
char **
|
1999-08-21 03:50:11 +08:00
|
|
|
charray_dup( char **a )
|
1998-08-09 08:43:13 +08:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
char **new;
|
|
|
|
|
|
|
|
for ( i = 0; a[i] != NULL; i++ )
|
|
|
|
; /* NULL */
|
|
|
|
|
|
|
|
new = (char **) ch_malloc( (i + 1) * sizeof(char *) );
|
|
|
|
|
|
|
|
for ( i = 0; a[i] != NULL; i++ ) {
|
1998-11-28 04:21:54 +08:00
|
|
|
new[i] = ch_strdup( a[i] );
|
1998-08-09 08:43:13 +08:00
|
|
|
}
|
|
|
|
new[i] = NULL;
|
|
|
|
|
|
|
|
return( new );
|
|
|
|
}
|
|
|
|
|
1999-07-16 10:45:46 +08:00
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
char **
|
1999-08-21 03:00:44 +08:00
|
|
|
str2charray( const char *str_in, const char *brkstr )
|
1998-08-09 08:43:13 +08:00
|
|
|
{
|
1999-08-21 03:00:44 +08:00
|
|
|
char *str;
|
1998-08-09 08:43:13 +08:00
|
|
|
char **res;
|
|
|
|
char *s;
|
1999-01-22 12:46:54 +08:00
|
|
|
char *lasts;
|
1998-08-09 08:43:13 +08:00
|
|
|
int i;
|
|
|
|
|
1998-08-14 03:32:43 +08:00
|
|
|
/* protect the input string from strtok */
|
1999-08-21 03:00:44 +08:00
|
|
|
str = ch_strdup( str_in );
|
1998-08-14 03:32:43 +08:00
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
i = 1;
|
|
|
|
for ( s = str; *s; s++ ) {
|
|
|
|
if ( strchr( brkstr, *s ) != NULL ) {
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
res = (char **) ch_malloc( (i + 1) * sizeof(char *) );
|
|
|
|
i = 0;
|
1999-01-02 04:43:29 +08:00
|
|
|
|
1999-02-21 04:12:03 +08:00
|
|
|
for ( s = ldap_pvt_strtok( str, brkstr, &lasts );
|
1999-01-22 12:46:54 +08:00
|
|
|
s != NULL;
|
1999-02-21 04:12:03 +08:00
|
|
|
s = ldap_pvt_strtok( NULL, brkstr, &lasts ) )
|
1999-01-22 12:46:54 +08:00
|
|
|
{
|
1998-11-28 04:21:54 +08:00
|
|
|
res[i++] = ch_strdup( s );
|
1998-08-09 08:43:13 +08:00
|
|
|
}
|
1999-01-02 04:43:29 +08:00
|
|
|
|
1998-08-09 08:43:13 +08:00
|
|
|
res[i] = NULL;
|
|
|
|
|
1998-08-14 03:32:43 +08:00
|
|
|
free( str );
|
1998-08-09 08:43:13 +08:00
|
|
|
return( res );
|
|
|
|
}
|
2001-07-06 20:20:26 +08:00
|
|
|
|
2001-12-26 16:17:44 +08:00
|
|
|
/* Convert a delimited string into an array of bervals; Add on
|
|
|
|
* to an existing array if it was given.
|
|
|
|
*/
|
|
|
|
struct berval **
|
|
|
|
str2bvec( struct berval **vec, const char *in, const char *brkstr )
|
|
|
|
{
|
|
|
|
char *str;
|
|
|
|
struct berval **res;
|
|
|
|
char *s;
|
|
|
|
char *lasts;
|
|
|
|
int i, old;
|
|
|
|
|
|
|
|
/* protect the input string from strtok */
|
|
|
|
str = ch_strdup( in );
|
|
|
|
|
|
|
|
for (old = 0; vec && vec[old]; old++);
|
|
|
|
|
|
|
|
i = 1;
|
|
|
|
for ( s = str; *s; s++ ) {
|
|
|
|
if ( strchr( brkstr, *s ) != NULL ) {
|
|
|
|
i++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (vec) {
|
|
|
|
res = (struct berval **) ch_realloc( vec, (old + i + 1) * sizeof(struct berval *) );
|
|
|
|
vec = res + old;
|
|
|
|
} else {
|
|
|
|
res = (struct berval **) ch_malloc( (i + 1) * sizeof(struct berval *) );
|
|
|
|
vec = res;
|
|
|
|
}
|
|
|
|
i = 0;
|
|
|
|
|
|
|
|
for ( s = ldap_pvt_strtok( str, brkstr, &lasts );
|
|
|
|
s != NULL;
|
|
|
|
s = ldap_pvt_strtok( NULL, brkstr, &lasts ) )
|
|
|
|
{
|
|
|
|
vec[i++] = ber_bvstrdup( s );
|
|
|
|
}
|
|
|
|
|
|
|
|
vec[i] = NULL;
|
|
|
|
|
|
|
|
free( str );
|
|
|
|
return( res );
|
|
|
|
}
|
|
|
|
|
2001-07-06 20:20:26 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
charray_strcmp( const char **a1, const char **a2 )
|
|
|
|
{
|
|
|
|
for ( ; a1[0] && a2[0]; a1++, a2++ ) {
|
|
|
|
if ( strcmp( a1[0], a2[0] ) ) {
|
|
|
|
return( !0 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! ( a1[0] && a2[0] ) ) {
|
|
|
|
return( !0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
charray_strcasecmp( const char **a1, const char **a2 )
|
|
|
|
{
|
|
|
|
for ( ; a1[0] && a2[0]; a1++, a2++ ) {
|
|
|
|
if ( strcasecmp( a1[0], a2[0] ) ) {
|
|
|
|
return( !0 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! ( a1[0] && a2[0] ) ) {
|
|
|
|
return( !0 );
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2001-12-26 23:52:46 +08:00
|
|
|
/* strcopy is like strcpy except it returns a pointer to the trailing NUL of
|
|
|
|
* the result string. This allows fast construction of catenated strings
|
|
|
|
* without the overhead of strlen/strcat.
|
|
|
|
*/
|
|
|
|
char *
|
|
|
|
slap_strcopy(
|
|
|
|
char *a,
|
|
|
|
char *b
|
|
|
|
)
|
|
|
|
{
|
|
|
|
if (!a || !b)
|
|
|
|
return a;
|
|
|
|
|
|
|
|
while (*a++ = *b++) ;
|
|
|
|
return a-1;
|
|
|
|
}
|