summaryrefslogtreecommitdiffstats
path: root/libft/src/ft_strjoin.c
diff options
context:
space:
mode:
authorRudy Bousset <rbousset@z2r5p6.le-101.fr>2019-10-30 15:00:17 +0100
committerRudy Bousset <rbousset@z2r5p6.le-101.fr>2019-10-30 15:00:17 +0100
commita3f3fc742daa4b28094b5ebe9be60263c41979d1 (patch)
tree5a6ce0fba04b55d6f4607038eeace0396e97f0e6 /libft/src/ft_strjoin.c
parentcommit, lotta stuff (diff)
download42-minishell-a3f3fc742daa4b28094b5ebe9be60263c41979d1.tar.gz
42-minishell-a3f3fc742daa4b28094b5ebe9be60263c41979d1.tar.bz2
42-minishell-a3f3fc742daa4b28094b5ebe9be60263c41979d1.tar.xz
42-minishell-a3f3fc742daa4b28094b5ebe9be60263c41979d1.tar.zst
42-minishell-a3f3fc742daa4b28094b5ebe9be60263c41979d1.zip
New libft, feelsgoodman
Diffstat (limited to 'libft/src/ft_strjoin.c')
-rw-r--r--libft/src/ft_strjoin.c68
1 files changed, 68 insertions, 0 deletions
diff --git a/libft/src/ft_strjoin.c b/libft/src/ft_strjoin.c
new file mode 100644
index 0000000..f666781
--- /dev/null
+++ b/libft/src/ft_strjoin.c
@@ -0,0 +1,68 @@
+/* ************************************************************************** */
+/* LE - / */
+/* / */
+/* ft_strjoin.c .:: .:/ . .:: */
+/* +:+:+ +: +: +:+:+ */
+/* By: rbousset <marvin@le-101.fr> +:+ +: +: +:+ */
+/* #+# #+ #+ #+# */
+/* Created: 2019/10/12 16:35:23 by rbousset #+# ## ## #+# */
+/* Updated: 2019/10/13 08:36:17 by rbousset ### #+. /#+ ###.fr */
+/* / */
+/* / */
+/* ************************************************************************** */
+
+#include "libft.h"
+#include <stdlib.h>
+
+size_t
+ ft_strleen(const char *s)
+{
+ size_t i;
+
+ i = 0;
+ while (s[i] != '\0')
+ i++;
+ return (i);
+}
+
+static char
+ *ft_recalloc(size_t size)
+{
+ char *str;
+
+ str = 0;
+ str = malloc((size + 1) * sizeof(char));
+ if (!str)
+ return (NULL);
+ ft_bzero(str, size);
+ return (str);
+}
+
+char
+ *ft_strjoin(const char *s1, const char *s2)
+{
+ char *str;
+ size_t i;
+ size_t j;
+ size_t size;
+
+ size = (ft_strleen(s1) + ft_strleen(s2));
+ str = (char*)ft_recalloc(ft_strleen(s1) + ft_strleen(s2));
+ i = 0;
+ j = 0;
+ if (!str)
+ return (NULL);
+ while (i < ft_strleen(s1))
+ {
+ str[i] = s1[i];
+ i++;
+ }
+ while (i < size)
+ {
+ str[i] = s2[j];
+ i++;
+ j++;
+ }
+ str[i] = '\0';
+ return (str);
+}