When saving project, create project directory if it doesn't exist
[ladish.git] / catdup.c
bloba1072e2b46df4712501fd29fbd10fd8882dfd1a5
1 /* -*- Mode: C ; c-basic-offset: 2 -*- */
2 /*
3 * LADI Session Handler (ladish)
5 * Copyright (C) 2009 Nedko Arnaudov <nedko@arnaudov.name>
7 **************************************************************************
8 * This file contains implementation of the catdup() function
9 **************************************************************************
11 * LADI Session Handler is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License as published by
13 * the Free Software Foundation; either version 2 of the License, or
14 * (at your option) any later version.
16 * LADI Session Handler is distributed in the hope that it will be useful,
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 * GNU General Public License for more details.
21 * You should have received a copy of the GNU General Public License
22 * along with LADI Session Handler. If not, see <http://www.gnu.org/licenses/>
23 * or write to the Free Software Foundation, Inc.,
24 * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
27 #include "common.h"
28 #include "catdup.h"
30 char * catdup(const char * s1, const char * s2)
32 char * buffer;
33 size_t s1_len, s2_len;
35 ASSERT(s1 != NULL && s2 != NULL);
37 s1_len = strlen(s1);
38 s2_len = strlen(s2);
40 buffer = malloc(s1_len + s2_len + 1);
41 if (buffer == NULL)
43 log_error("malloc() failed.");
44 return NULL;
47 memcpy(buffer, s1, s1_len);
48 memcpy(buffer + s1_len, s2, s2_len);
49 buffer[s1_len + s2_len] = 0;
51 return buffer;
54 char * catdup3(const char * s1, const char * s2, const char * s3)
56 char * buffer;
57 size_t s1_len, s2_len, s3_len;
59 ASSERT(s1 != NULL && s2 != NULL && s3 != NULL);
61 s1_len = strlen(s1);
62 s2_len = strlen(s2);
63 s3_len = strlen(s3);
65 buffer = malloc(s1_len + s2_len + s3_len + 1);
66 if (buffer == NULL)
68 log_error("malloc() failed.");
69 return NULL;
72 memcpy(buffer, s1, s1_len);
73 memcpy(buffer + s1_len, s2, s2_len);
74 memcpy(buffer + s1_len + s2_len, s3, s3_len);
75 buffer[s1_len + s2_len + s3_len] = 0;
77 return buffer;
80 char * catdup4(const char * s1, const char * s2, const char * s3, const char * s4)
82 char * buffer;
83 size_t s1_len, s2_len, s3_len, s4_len;
85 ASSERT(s1 != NULL && s2 != NULL && s3 != NULL && s4 != NULL);
87 s1_len = strlen(s1);
88 s2_len = strlen(s2);
89 s3_len = strlen(s3);
90 s4_len = strlen(s4);
92 buffer = malloc(s1_len + s2_len + s3_len + s4_len + 1);
93 if (buffer == NULL)
95 log_error("malloc() failed.");
96 return NULL;
99 memcpy(buffer, s1, s1_len);
100 memcpy(buffer + s1_len, s2, s2_len);
101 memcpy(buffer + s1_len + s2_len, s3, s3_len);
102 memcpy(buffer + s1_len + s2_len + s3_len, s4, s4_len);
103 buffer[s1_len + s2_len + s3_len + s4_len] = 0;
105 return buffer;