-
Notifications
You must be signed in to change notification settings - Fork 24
/
ft_memmove.c
41 lines (37 loc) · 2.1 KB
/
ft_memmove.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_memmove.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: pbie <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2015/11/26 17:11:32 by pbie #+# #+# */
/* Updated: 2015/12/07 22:44:13 by pbie ### ########.fr */
/* */
/* ************************************************************************** */
#include "libft.h"
/*According to the man this function copies len bytes from string src to string
* dst. The two strings may overlap; the copy is always done in a non
* destructive manner. The ft_memmove function returns the original value of
* dst.*/
void *ft_memmove(void *dst, const void *src, size_t len)
{
/*We start by creating a char pointer variable tmp which we will use to
* move len bytes of src into and then we will move the len bytes of src we
* placed into tmp into dst. We do this using our ft_memcpy function. But
* before we do this we have to make sure to allocate memory for tmp to be
* able to hold the bytes of src to move them to dst. We use our given len
* parameter to determine the size of the malloc for tmp. If the allocation
* fails we will return NULL. If not we will go ahead and use ft_memcpy
* first on tmp, src, and len, and then we will call it again on dst, tmp,
* and len. Once our memory move is finished we will then free the memory
* we allocated for tmp. And last we will return the original value of dst.*/
char *tmp;
tmp = (char *)malloc(sizeof(char) * len);
if (tmp == NULL)
return (NULL);
ft_memcpy(tmp, src, len);
ft_memcpy(dst, tmp, len);
free(tmp);
return (dst);
}