」 feat(Prompt): prompt working

This commit is contained in:
2024-04-27 17:39:26 +02:00
parent 6c254630fa
commit 5c7a4e8b5a
19 changed files with 121 additions and 83 deletions

View File

@ -6,7 +6,7 @@
# By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ #
# +#+#+#+#+#+ +#+ #
# Created: 2023/11/01 11:03:22 by adjoly #+# #+# #
# Updated: 2024/03/18 14:33:40 by adjoly ### ########.fr #
# Updated: 2024/04/27 17:17:00 by adjoly ### ########.fr #
# #
# **************************************************************************** #
@ -37,6 +37,7 @@ SRCS = is/ft_isalnum.c \
mem/ft_memcpy.c \
mem/ft_memmove.c \
mem/ft_memset.c \
mem/ft_freetab.c \
print/ft_putchar.c \
print/ft_putchar_fd.c \
print/ft_putendl_fd.c \
@ -70,16 +71,16 @@ SRCS = is/ft_isalnum.c \
print/printf/ft_putnbrbase.c \
print/printf/ft_putnbr.c \
print/printf/ft_putstr.c \
io/get_next_line/get_next_line.c \
io/get_next_line/get_next_line_utils.c \
OBJS = $(addprefix $(OBJSDIR),$(SRCS:.c=.o))
FLAGS = -Werror -Wall -Wextra -g
LIB = io/get_next_line/get_next_line.a
$(NAME): $(OBJS)
@make -s -C io/get_next_line/
@ar -rcs $(NAME) $(OBJS) $(LIB)
@ar -rcs $(NAME) $(OBJS)
@echo "[✔] Libft compiled"
$(OBJSDIR)%.o: %.c
@ -89,11 +90,9 @@ $(OBJSDIR)%.o: %.c
all: $(NAME)
clean:
@make -s -C io/get_next_line/ clean
@rm -f $(OBJS)
fclean: clean
@make -s -C io/get_next_line/ fclean
@rm -f $(NAME)
@echo "[X] Libft cleaned"

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:11:59 by adjoly #+# #+# */
/* Updated: 2024/02/04 14:23:07 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:25:28 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "get_next_line.h"
#include "../../libft.h"
char check_line(char *res, char *buf)
{

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:12:02 by adjoly #+# #+# */
/* Updated: 2024/03/16 21:45:27 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:25:44 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "get_next_line.h"
#include "../../libft.h"
char *ft_strjoin_gnl(char *s1, char *s2)
{

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/01 10:06:03 by adjoly #+# #+# */
/* Updated: 2024/03/16 21:45:08 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:27:45 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
@ -16,13 +16,15 @@
# include <stddef.h>
# include <stdlib.h>
# include <unistd.h>
# include "print/printf/ft_printf.h"
# include "io/get_next_line/get_next_line.h"
# include <stdarg.h>
# define INT_MAX 2147483647
# define INT_MIN -2147483648
# ifndef BUFFER_SIZE
# define BUFFER_SIZE 5
# endif
typedef struct s_list
{
void *content;
@ -36,6 +38,7 @@ typedef enum s_boolean
TRUE,
} t_boolean;
char *ft_strjoinvaarg(char *src, ...);
long long ft_atoll(const char *nptr);
int ft_atoi(const char *nptr);
void *ft_calloc(size_t nmemb, size_t size);
@ -84,6 +87,10 @@ void ft_lstclear(t_list **lst, void (*del)(void *));
void ft_lstiter(t_list *lst, void (*f)(void *));
t_list *ft_lstmap(t_list *lst, void *(*f)(void *), void (*del)(void *));
char *get_next_line(int fd);
char *ft_strjoin_gnl(char *s1, char *s2);
void *ft_calloc(size_t nmemb, size_t size);
void ft_putchar(char c);
void ft_putstr(char *s);
void ft_putnbrbase_fd(int n, char *base, int fd);
@ -95,10 +102,12 @@ int ft_printconversion(char conversion, va_list args);
int ft_putnbrulong(unsigned int n);
int ft_putaddr(void *ptr);
int ft_putstr_p(char *s);
int ft_putnbrbase_p(unsigned long int n, char *base);
int ft_putnbrbasep(unsigned long int n, char *base);
int ft_putnbrbase_pf(unsigned int n, char *base);
int ft_putchar_p(char c);
int ft_putnbr_p(int n);
size_t ft_strlen(const char *s);
void ft_freearr(void **arr);
#endif

View File

@ -1,28 +1,26 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* get_next_line.h :+: :+: :+: */
/* ft_freetab.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */
/* Updated: 2024/02/04 15:24:21 by adjoly ### ########.fr */
/* Created: 2024/04/27 15:33:20 by adjoly #+# #+# */
/* Updated: 2024/04/27 17:20:24 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef GET_NEXT_LINE_H
# define GET_NEXT_LINE_H
#include <stdlib.h>
# include <unistd.h>
# include <stdlib.h>
void ft_freearr(void **arr)
{
void **tmp;
# ifndef BUFFER_SIZE
# define BUFFER_SIZE 1
# endif
char *get_next_line(int fd);
char *ft_strjoin_gnl(char *s1, char *s2);
void *ft_calloc(size_t nmemb, size_t size);
size_t ft_strlen(const char *s);
#endif
tmp = arr;
while (*tmp)
{
free(*tmp);
tmp++;
}
free(arr);
}

Binary file not shown.

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/17 16:48:37 by adjoly #+# #+# */
/* Updated: 2024/03/16 21:46:36 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:27:13 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_printf.h"
#include "../../libft.h"
int ft_putaddr(void *ptr)
{
@ -19,7 +19,7 @@ int ft_putaddr(void *ptr)
if (ptr == NULL)
return (write(1, "(nil)", 5));
write(1, "0x", 2);
r = ft_putnbrbase_p((long unsigned int)ptr, "0123456789abcdef");
r = ft_putnbrbasep((long unsigned int)ptr, "0123456789abcdef");
return (2 + r);
}
@ -56,9 +56,9 @@ int ft_printconversion(char conversion, va_list args)
else if (conversion == 'p')
count = ft_putaddr(va_arg(args, void *));
else if (conversion == 'x')
count = ft_pputnbrbase(va_arg(args, unsigned long), "0123456789abcdef");
count = ft_putnbrbasep(va_arg(args, unsigned long), "0123456789abcdef");
else if (conversion == 'X')
count = ft_pputnbrbase(va_arg(args, unsigned long), "0123456789ABCDEF");
count = ft_putnbrbasep(va_arg(args, unsigned long), "0123456789ABCDEF");
return (count);
}

View File

@ -1,33 +0,0 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_printf.h :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/17 16:50:36 by adjoly #+# #+# */
/* Updated: 2024/03/16 21:47:28 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#ifndef FT_PRINTF_H
# define FT_PRINTF_H
# include <stdlib.h>
# include <stdarg.h>
# include <unistd.h>
int ft_printf(const char *format, ...);
int ft_printconversion(char conversion, va_list args);
int ft_putnbrulong(unsigned int n);
int ft_putaddr(void *ptr);
int ft_putstr_p(char *s);
int ft_putnbrbase_p(unsigned long int n, char *base);
int ft_pputnbrbase(unsigned int n, char *base);
int ft_putchar_p(char c);
int ft_putnbr_p(int n);
size_t ft_strlen(const char *s);
#endif

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 10:49:00 by adjoly #+# #+# */
/* Updated: 2024/02/04 15:17:42 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:22:30 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_printf.h"
#include <unistd.h>
int ft_putchar_p(char c)
{

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/10/31 11:52:46 by adjoly #+# #+# */
/* Updated: 2024/02/04 15:20:26 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:24:27 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_printf.h"
#include "../../libft.h"
int ft_putnbr_p(int n)
{

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/18 10:57:44 by adjoly #+# #+# */
/* Updated: 2024/02/04 15:21:56 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:29:04 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_printf.h"
#include "../../libft.h"
int ft_putnbrbase_pf(unsigned int n, char *base)
{
@ -29,7 +29,7 @@ int ft_putnbrbase_pf(unsigned int n, char *base)
return (len);
}
int ft_putnbrbase_p(unsigned long int n, char *base)
int ft_putnbrbasep(unsigned long int n, char *base)
{
unsigned long int base_len;
int len;
@ -40,7 +40,7 @@ int ft_putnbrbase_p(unsigned long int n, char *base)
len += write(1, &base[n % base_len], 1);
else
{
len += ft_putnbrbase_p(n / base_len, base);
len += ft_putnbrbasep(n / base_len, base);
len += write(1, &base[n % base_len], 1);
}
return (len);

View File

@ -6,11 +6,11 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/10/31 11:45:55 by adjoly #+# #+# */
/* Updated: 2024/03/12 15:05:16 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:24:56 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "ft_printf.h"
#include "../../libft.h"
int ft_putstr_p(char *s)
{

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2023/11/12 09:14:19 by adjoly #+# #+# */
/* Updated: 2024/02/04 14:43:50 by adjoly ### ########.fr */
/* Updated: 2024/04/27 17:21:29 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
@ -38,7 +38,7 @@ static int ft_countletter(char const *s, char sep)
return (i);
}
static void *ft_freearr(char **arr)
static void *ft_freearr_s(char **arr)
{
int i;
@ -67,7 +67,7 @@ char **ft_split_to_result(char **tab, char const *s, char c)
k = 0;
tab[j] = ft_calloc(ft_countletter(&s[i], c) + 1, sizeof(char));
if (!tab[j])
return (ft_freearr(tab));
return (ft_freearr_s(tab));
while (s[i] && s[i] != c)
tab[j][k++] = s [i++];
tab[j][k] = '\0';