123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275 |
- /* charray.c - routines for dealing with char * arrays */
- /* $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>.
- */
- #include "portable.h"
- #include <stdio.h>
- #include <ac/string.h>
- #include <ac/socket.h>
- #include "ldap-int.h"
- int
- ldap_charray_add(
- char ***a,
- const char *s
- )
- {
- int n;
- if ( *a == NULL ) {
- *a = (char **) LDAP_MALLOC( 2 * sizeof(char *) );
- n = 0;
- if( *a == NULL ) {
- return -1;
- }
- } else {
- char **new;
- for ( n = 0; *a != NULL && (*a)[n] != NULL; n++ ) {
- ; /* NULL */
- }
- new = (char **) LDAP_REALLOC( (char *) *a,
- (n + 2) * sizeof(char *) );
- if( new == NULL ) {
- /* caller is required to call ldap_charray_free(*a) */
- return -1;
- }
- *a = new;
- }
- (*a)[n] = LDAP_STRDUP(s);
- if( (*a)[n] == NULL ) {
- return 1;
- }
- (*a)[++n] = NULL;
- return 0;
- }
- int
- ldap_charray_merge(
- char ***a,
- char **s
- )
- {
- int i, n, nn;
- char **aa;
- for ( n = 0; *a != NULL && (*a)[n] != NULL; n++ ) {
- ; /* NULL */
- }
- for ( nn = 0; s[nn] != NULL; nn++ ) {
- ; /* NULL */
- }
- aa = (char **) LDAP_REALLOC( (char *) *a, (n + nn + 1) * sizeof(char *) );
- if( aa == NULL ) {
- return -1;
- }
- *a = aa;
- for ( i = 0; i < nn; i++ ) {
- (*a)[n + i] = LDAP_STRDUP(s[i]);
- if( (*a)[n + i] == NULL ) {
- for( --i ; i >= 0 ; i-- ) {
- LDAP_FREE( (*a)[n + i] );
- (*a)[n + i] = NULL;
- }
- return -1;
- }
- }
- (*a)[n + nn] = NULL;
- return 0;
- }
- void
- ldap_charray_free( char **a )
- {
- char **p;
- if ( a == NULL ) {
- return;
- }
- for ( p = a; *p != NULL; p++ ) {
- if ( *p != NULL ) {
- LDAP_FREE( *p );
- }
- }
- LDAP_FREE( (char *) a );
- }
- int
- ldap_charray_inlist(
- char **a,
- const char *s
- )
- {
- int i;
- if( a == NULL ) return 0;
- for ( i=0; a[i] != NULL; i++ ) {
- if ( strcasecmp( s, a[i] ) == 0 ) {
- return 1;
- }
- }
- return 0;
- }
- char **
- ldap_charray_dup( char **a )
- {
- int i;
- char **new;
- for ( i = 0; a[i] != NULL; i++ )
- ; /* NULL */
- new = (char **) LDAP_MALLOC( (i + 1) * sizeof(char *) );
- if( new == NULL ) {
- return NULL;
- }
- for ( i = 0; a[i] != NULL; i++ ) {
- new[i] = LDAP_STRDUP( a[i] );
- if( new[i] == NULL ) {
- for( --i ; i >= 0 ; i-- ) {
- LDAP_FREE( new[i] );
- }
- LDAP_FREE( new );
- return NULL;
- }
- }
- new[i] = NULL;
- return( new );
- }
- char **
- ldap_str2charray( const char *str_in, const char *brkstr )
- {
- char **res;
- char *str, *s;
- char *lasts;
- int i;
- /* protect the input string from strtok */
- str = LDAP_STRDUP( str_in );
- if( str == NULL ) {
- return NULL;
- }
- i = 1;
- for ( s = str; ; LDAP_UTF8_INCR(s) ) {
- s = ldap_utf8_strpbrk( s, brkstr );
- if ( !s ) break;
- i++;
- }
- res = (char **) LDAP_MALLOC( (i + 1) * sizeof(char *) );
- if( res == NULL ) {
- LDAP_FREE( str );
- return NULL;
- }
- i = 0;
- for ( s = ldap_utf8_strtok( str, brkstr, &lasts );
- s != NULL;
- s = ldap_utf8_strtok( NULL, brkstr, &lasts ) )
- {
- res[i] = LDAP_STRDUP( s );
- if(res[i] == NULL) {
- for( --i ; i >= 0 ; i-- ) {
- LDAP_FREE( res[i] );
- }
- LDAP_FREE( res );
- LDAP_FREE( str );
- return NULL;
- }
- i++;
- }
- res[i] = NULL;
- LDAP_FREE( str );
- return( res );
- }
- char * ldap_charray2str( char **a, const char *sep )
- {
- char *s, **v, *p;
- int len;
- int slen;
- if( sep == NULL ) sep = " ";
- slen = strlen( sep );
- len = 0;
- for ( v = a; *v != NULL; v++ ) {
- len += strlen( *v ) + slen;
- }
- if ( len == 0 ) {
- return NULL;
- }
- /* trim extra sep len */
- len -= slen;
- s = LDAP_MALLOC ( len + 1 );
- if ( s == NULL ) {
- return NULL;
- }
- p = s;
- for ( v = a; *v != NULL; v++ ) {
- if ( v != a ) {
- strncpy( p, sep, slen );
- p += slen;
- }
- len = strlen( *v );
- strncpy( p, *v, len );
- p += len;
- }
- *p = '\0';
- return s;
- }
|