2009-08-05 21:40:55 +03:00
|
|
|
/* -*- Mode: C ; c-basic-offset: 2 -*- */
|
|
|
|
/*
|
|
|
|
* LADI Session Handler (ladish)
|
|
|
|
*
|
2012-11-17 15:36:00 +02:00
|
|
|
* Copyright (C) 2009,2010,2012 Nedko Arnaudov <nedko@arnaudov.name>
|
2009-08-05 21:40:55 +03:00
|
|
|
*
|
|
|
|
**************************************************************************
|
|
|
|
* This file contains implementation of the catdup() function
|
|
|
|
**************************************************************************
|
|
|
|
*
|
|
|
|
* LADI Session Handler is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* LADI Session Handler is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with LADI Session Handler. If not, see <http://www.gnu.org/licenses/>
|
|
|
|
* or write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
|
|
|
|
2010-09-19 17:15:11 +03:00
|
|
|
#include "../common.h"
|
2010-09-20 00:22:19 +03:00
|
|
|
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
2009-08-05 21:40:55 +03:00
|
|
|
#include "catdup.h"
|
|
|
|
|
|
|
|
char * catdup(const char * s1, const char * s2)
|
|
|
|
{
|
|
|
|
char * buffer;
|
|
|
|
size_t s1_len, s2_len;
|
|
|
|
|
2009-09-20 18:48:42 +03:00
|
|
|
ASSERT(s1 != NULL && s2 != NULL);
|
2009-08-05 21:40:55 +03:00
|
|
|
|
|
|
|
s1_len = strlen(s1);
|
|
|
|
s2_len = strlen(s2);
|
|
|
|
|
|
|
|
buffer = malloc(s1_len + s2_len + 1);
|
|
|
|
if (buffer == NULL)
|
|
|
|
{
|
2009-09-20 18:23:42 +03:00
|
|
|
log_error("malloc() failed.");
|
2009-08-05 21:40:55 +03:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(buffer, s1, s1_len);
|
|
|
|
memcpy(buffer + s1_len, s2, s2_len);
|
|
|
|
buffer[s1_len + s2_len] = 0;
|
|
|
|
|
|
|
|
return buffer;
|
|
|
|
}
|
2009-08-24 03:52:18 +03:00
|
|
|
|
|
|
|
char * catdup3(const char * s1, const char * s2, const char * s3)
|
|
|
|
{
|
|
|
|
char * buffer;
|
|
|
|
size_t s1_len, s2_len, s3_len;
|
|
|
|
|
2009-09-20 18:48:42 +03:00
|
|
|
ASSERT(s1 != NULL && s2 != NULL && s3 != NULL);
|
2009-08-24 03:52:18 +03:00
|
|
|
|
|
|
|
s1_len = strlen(s1);
|
|
|
|
s2_len = strlen(s2);
|
|
|
|
s3_len = strlen(s3);
|
|
|
|
|
|
|
|
buffer = malloc(s1_len + s2_len + s3_len + 1);
|
|
|
|
if (buffer == NULL)
|
|
|
|
{
|
2009-09-20 18:23:42 +03:00
|
|
|
log_error("malloc() failed.");
|
2009-08-24 03:52:18 +03:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(buffer, s1, s1_len);
|
|
|
|
memcpy(buffer + s1_len, s2, s2_len);
|
|
|
|
memcpy(buffer + s1_len + s2_len, s3, s3_len);
|
|
|
|
buffer[s1_len + s2_len + s3_len] = 0;
|
|
|
|
|
|
|
|
return buffer;
|
|
|
|
}
|
2009-12-12 15:10:06 +02:00
|
|
|
|
|
|
|
char * catdup4(const char * s1, const char * s2, const char * s3, const char * s4)
|
|
|
|
{
|
|
|
|
char * buffer;
|
|
|
|
size_t s1_len, s2_len, s3_len, s4_len;
|
|
|
|
|
|
|
|
ASSERT(s1 != NULL && s2 != NULL && s3 != NULL && s4 != NULL);
|
|
|
|
|
|
|
|
s1_len = strlen(s1);
|
|
|
|
s2_len = strlen(s2);
|
|
|
|
s3_len = strlen(s3);
|
|
|
|
s4_len = strlen(s4);
|
|
|
|
|
|
|
|
buffer = malloc(s1_len + s2_len + s3_len + s4_len + 1);
|
|
|
|
if (buffer == NULL)
|
|
|
|
{
|
|
|
|
log_error("malloc() failed.");
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(buffer, s1, s1_len);
|
|
|
|
memcpy(buffer + s1_len, s2, s2_len);
|
|
|
|
memcpy(buffer + s1_len + s2_len, s3, s3_len);
|
|
|
|
memcpy(buffer + s1_len + s2_len + s3_len, s4, s4_len);
|
|
|
|
buffer[s1_len + s2_len + s3_len + s4_len] = 0;
|
|
|
|
|
|
|
|
return buffer;
|
|
|
|
}
|
2010-09-20 00:22:19 +03:00
|
|
|
|
|
|
|
char * catdupv(const char * s1, const char * s2, ...)
|
|
|
|
{
|
|
|
|
va_list ap;
|
|
|
|
const char * str;
|
|
|
|
size_t len;
|
|
|
|
char * buffer;
|
|
|
|
char * p;
|
|
|
|
|
|
|
|
len = strlen(s1) + strlen(s2);
|
|
|
|
va_start(ap, s2);
|
|
|
|
while ((str = va_arg(ap, const char *)) != NULL)
|
|
|
|
{
|
|
|
|
len += strlen(str);
|
|
|
|
}
|
|
|
|
va_end(ap);
|
|
|
|
len++;
|
|
|
|
|
|
|
|
buffer = malloc(len);
|
|
|
|
if (buffer == NULL)
|
|
|
|
{
|
|
|
|
log_error("malloc(%zu) failed.", len);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
len = strlen(s1);
|
|
|
|
memcpy(buffer, s1, len);
|
|
|
|
p = buffer + len;
|
|
|
|
|
|
|
|
len = strlen(s2);
|
|
|
|
memcpy(p, s2, len);
|
|
|
|
p += len;
|
|
|
|
|
|
|
|
va_start(ap, s2);
|
|
|
|
while ((str = va_arg(ap, const char *)) != NULL)
|
|
|
|
{
|
|
|
|
len = strlen(str);
|
|
|
|
memcpy(p, str, len);
|
|
|
|
p += len;
|
|
|
|
}
|
|
|
|
va_end(ap);
|
|
|
|
|
|
|
|
*p = 0;
|
|
|
|
|
|
|
|
return buffer;
|
|
|
|
}
|
2010-12-22 16:58:16 +02:00
|
|
|
|
|
|
|
char * catdup_array(const char ** array, const char * delimiter)
|
|
|
|
{
|
|
|
|
size_t len;
|
|
|
|
size_t i;
|
|
|
|
size_t delimiter_length;
|
|
|
|
char * buffer;
|
|
|
|
char * p;
|
|
|
|
|
|
|
|
delimiter_length = delimiter != NULL ? strlen(delimiter) : 0;
|
|
|
|
|
|
|
|
len = 0;
|
|
|
|
for (i = 0; array[i] != NULL; i++)
|
|
|
|
{
|
|
|
|
len += strlen(array[i]);
|
|
|
|
len += delimiter_length;
|
|
|
|
}
|
2010-12-27 03:56:59 +02:00
|
|
|
len++;
|
2010-12-22 16:58:16 +02:00
|
|
|
|
|
|
|
buffer = malloc(len);
|
|
|
|
if (buffer == NULL)
|
|
|
|
{
|
|
|
|
log_error("malloc(%zu) failed.", len);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
p = buffer;
|
|
|
|
for (i = 0; array[i] != NULL; i++)
|
|
|
|
{
|
|
|
|
len = strlen(array[i]);
|
|
|
|
memcpy(p, array[i], len);
|
|
|
|
p += len;
|
2012-11-17 15:36:00 +02:00
|
|
|
if (delimiter_length > 0)
|
|
|
|
{
|
|
|
|
memcpy(p, delimiter, delimiter_length);
|
|
|
|
p += delimiter_length;
|
|
|
|
}
|
2010-12-22 16:58:16 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
*p = 0;
|
|
|
|
|
|
|
|
return buffer;
|
|
|
|
}
|