aboutsummaryrefslogtreecommitdiff
path: root/src/io
diff options
context:
space:
mode:
Diffstat (limited to 'src/io')
-rw-r--r--src/io/ft_getfile.c35
1 files changed, 19 insertions, 16 deletions
diff --git a/src/io/ft_getfile.c b/src/io/ft_getfile.c
index 891ea51..d3f697c 100644
--- a/src/io/ft_getfile.c
+++ b/src/io/ft_getfile.c
@@ -6,32 +6,35 @@
/* By: charles <charles.cabergs@gmail.com> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2020/05/11 09:52:32 by charles #+# #+# */
-/* Updated: 2020/05/11 10:15:12 by charles ### ########.fr */
+/* Updated: 2020/05/11 16:09:31 by charles ### ########.fr */
/* */
/* ************************************************************************** */
#include "libft_io.h"
-char *ft_getfile(int fd)
+/*
+** \brief Read a file in a memory buffer
+** \param fd File descriptor to read from
+** \param mem Pointer to mem struct (buffer and buffer size)
+** \return -1 on error, 0 otherwise
+*/
+
+int ft_getfile(int fd, t_ftmem *mem)
{
- char *s;
- char buf[FT_GETFILE_BUFFER_SIZE + 1];
+ char buf[FT_GETFILE_BUFFER_SIZE];
int ret;
- if (fd < 0 || fd > OPEN_MAX)
- return (NULL);
- if ((s = ft_strdup("")) == NULL)
- return (NULL);
+ if (fd < 0 || fd > OPEN_MAX || mem == NULL
+ || (mem->data = malloc(1)) == NULL)
+ return (-1);
+ mem->size = 0;
while ((ret = read(fd, buf, FT_GETFILE_BUFFER_SIZE)) > 0)
{
- buf[ret] = '\0';
- if ((s = ft_strjoinf(s, buf, FT_STRJOINF_FST)) == NULL)
- return (NULL);
+ if ((mem->data = ft_memjoinf1(mem->data, mem->size, buf, ret)) == NULL)
+ return (-1);
+ mem->size += ret;
}
if (ret == -1)
- {
- free(s);
- return (NULL);
- }
- return (s);
+ free(mem->data);
+ return (ret);
}