add printf
This commit is contained in:
5
Makefile
5
Makefile
@ -6,7 +6,7 @@
|
|||||||
# By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ #
|
# By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2023/11/01 11:03:22 by adjoly #+# #+# #
|
# Created: 2023/11/01 11:03:22 by adjoly #+# #+# #
|
||||||
# Updated: 2024/02/04 15:03:34 by adjoly ### ########.fr #
|
# Updated: 2024/02/04 15:15:14 by adjoly ### ########.fr #
|
||||||
# #
|
# #
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #
|
||||||
|
|
||||||
@ -69,7 +69,8 @@ FLAGS = -Werror -Wall -Wextra -g
|
|||||||
|
|
||||||
HEADERS = libft.h
|
HEADERS = libft.h
|
||||||
|
|
||||||
LIB = print/printf/libftprintf.a
|
LIB = print/printf/libftprintf.a \
|
||||||
|
io/get_next_line/get_next_line.a
|
||||||
|
|
||||||
$(NAME): $(OBJS)
|
$(NAME): $(OBJS)
|
||||||
make -C io/get_next_line/
|
make -C io/get_next_line/
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */
|
/* Created: 2023/12/01 17:12:00 by adjoly #+# #+# */
|
||||||
/* Updated: 2024/02/04 14:26:01 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:24:21 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -23,6 +23,6 @@
|
|||||||
char *get_next_line(int fd);
|
char *get_next_line(int fd);
|
||||||
char *ft_strjoin_gnl(char *s1, char *s2);
|
char *ft_strjoin_gnl(char *s1, char *s2);
|
||||||
void *ft_calloc(size_t nmemb, size_t size);
|
void *ft_calloc(size_t nmemb, size_t size);
|
||||||
size_t ft_strlen(char *s);
|
size_t ft_strlen(const char *s);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -3,10 +3,10 @@
|
|||||||
# ::: :::::::: #
|
# ::: :::::::: #
|
||||||
# Makefile :+: :+: :+: #
|
# Makefile :+: :+: :+: #
|
||||||
# +:+ +:+ +:+ #
|
# +:+ +:+ +:+ #
|
||||||
# By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ #
|
# By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2023/11/17 12:35:27 by adjoly #+# #+# #
|
# Created: 2023/11/17 12:35:27 by adjoly #+# #+# #
|
||||||
# Updated: 2023/11/20 15:55:52 by adjoly ### ########.fr #
|
# Updated: 2024/02/04 15:18:46 by adjoly ### ########.fr #
|
||||||
# #
|
# #
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #
|
||||||
|
|
||||||
@ -19,7 +19,7 @@ SRCS = ft_printf.c \
|
|||||||
ft_putnbr.c \
|
ft_putnbr.c \
|
||||||
ft_putnbrbase.c \
|
ft_putnbrbase.c \
|
||||||
ft_putstr.c \
|
ft_putstr.c \
|
||||||
ft_strlen.c \
|
../../str/ft_strlen.c \
|
||||||
|
|
||||||
OBJS = $(SRCS:.c=.o)
|
OBJS = $(SRCS:.c=.o)
|
||||||
|
|
||||||
|
@ -3,10 +3,10 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* ft_printf.c :+: :+: :+: */
|
/* ft_printf.c :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/11/17 16:48:37 by adjoly #+# #+# */
|
/* Created: 2023/11/17 16:48:37 by adjoly #+# #+# */
|
||||||
/* Updated: 2023/12/06 14:27:05 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:23:15 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -44,21 +44,21 @@ int ft_printconversion(char conversion, va_list args)
|
|||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
if (conversion == '%')
|
if (conversion == '%')
|
||||||
count = ft_putchar('%');
|
count = ft_putchar_p('%');
|
||||||
else if (conversion == 's')
|
else if (conversion == 's')
|
||||||
count = ft_putstr(va_arg(args, char *));
|
count = ft_putstr_p(va_arg(args, char *));
|
||||||
else if (conversion == 'c')
|
else if (conversion == 'c')
|
||||||
count = ft_putchar(va_arg(args, int));
|
count = ft_putchar_p(va_arg(args, int));
|
||||||
else if (conversion == 'i' || conversion == 'd')
|
else if (conversion == 'i' || conversion == 'd')
|
||||||
count = ft_putnbr(va_arg(args, int));
|
count = ft_putnbr_p(va_arg(args, int));
|
||||||
else if (conversion == 'u')
|
else if (conversion == 'u')
|
||||||
count = ft_putnbrulong(va_arg(args, unsigned int));
|
count = ft_putnbrulong(va_arg(args, unsigned int));
|
||||||
else if (conversion == 'p')
|
else if (conversion == 'p')
|
||||||
count = ft_putaddr(va_arg(args, void *));
|
count = ft_putaddr(va_arg(args, void *));
|
||||||
else if (conversion == 'x')
|
else if (conversion == 'x')
|
||||||
count = ft_putnbrbase(va_arg(args, unsigned long), "0123456789abcdef");
|
count = ft_putnbrbase_pf(va_arg(args, unsigned long), "0123456789abcdef");
|
||||||
else if (conversion == 'X')
|
else if (conversion == 'X')
|
||||||
count = ft_putnbrbase(va_arg(args, unsigned long), "0123456789ABCDEF");
|
count = ft_putnbrbase_pf(va_arg(args, unsigned long), "0123456789ABCDEF");
|
||||||
return (count);
|
return (count);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -84,7 +84,7 @@ int ft_printf(const char *format, ...)
|
|||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
count += ft_putchar(format[i]);
|
count += ft_putchar_p(format[i]);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
va_end(args);
|
va_end(args);
|
||||||
|
@ -3,10 +3,10 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* ft_printf.h :+: :+: :+: */
|
/* ft_printf.h :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/11/17 16:50:36 by adjoly #+# #+# */
|
/* Created: 2023/11/17 16:50:36 by adjoly #+# #+# */
|
||||||
/* Updated: 2023/11/22 14:00:38 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:23:39 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@ -22,12 +22,12 @@ int ft_printconversion(char conversion, va_list args);
|
|||||||
int ft_putnbrulong(unsigned int n);
|
int ft_putnbrulong(unsigned int n);
|
||||||
int ft_putaddr(void *ptr);
|
int ft_putaddr(void *ptr);
|
||||||
|
|
||||||
int ft_putstr(char *s);
|
int ft_putstr_p(char *s);
|
||||||
|
|
||||||
int ft_putnbrbase_p(unsigned long int n, char *base);
|
int ft_putnbrbase_p(unsigned long int n, char *base);
|
||||||
int ft_putnbrbase(unsigned int n, char *base);
|
int ft_putnbrbase_pf(unsigned int n, char *base);
|
||||||
int ft_putchar(char c);
|
int ft_putchar_p(char c);
|
||||||
int ft_putnbr(int n);
|
int ft_putnbr_p(int n);
|
||||||
size_t ft_strlen(const char *s);
|
size_t ft_strlen(const char *s);
|
||||||
|
|
||||||
#endif
|
#endif
|
@ -3,16 +3,16 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* ft_putchar.c :+: :+: :+: */
|
/* ft_putchar.c :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/11/18 10:49:00 by adjoly #+# #+# */
|
/* Created: 2023/11/18 10:49:00 by adjoly #+# #+# */
|
||||||
/* Updated: 2023/11/22 11:07:22 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:17:42 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "ft_printf.h"
|
#include "ft_printf.h"
|
||||||
|
|
||||||
int ft_putchar(char c)
|
int ft_putchar_p(char c)
|
||||||
{
|
{
|
||||||
write(1, &c, 1);
|
write(1, &c, 1);
|
||||||
return (1);
|
return (1);
|
||||||
|
@ -3,16 +3,16 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* ft_putnbr.c :+: :+: :+: */
|
/* ft_putnbr.c :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/10/31 11:52:46 by adjoly #+# #+# */
|
/* Created: 2023/10/31 11:52:46 by adjoly #+# #+# */
|
||||||
/* Updated: 2023/11/22 10:51:24 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:20:26 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "ft_printf.h"
|
#include "ft_printf.h"
|
||||||
|
|
||||||
int ft_putnbr(int n)
|
int ft_putnbr_p(int n)
|
||||||
{
|
{
|
||||||
unsigned int nbr;
|
unsigned int nbr;
|
||||||
int len;
|
int len;
|
||||||
@ -29,7 +29,7 @@ int ft_putnbr(int n)
|
|||||||
len += write(1, &(char){nbr + '0'}, 1);
|
len += write(1, &(char){nbr + '0'}, 1);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
len += ft_putnbr(nbr / 10);
|
len += ft_putnbr_p(nbr / 10);
|
||||||
len += write(1, &(char){nbr % 10 + '0'}, 1);
|
len += write(1, &(char){nbr % 10 + '0'}, 1);
|
||||||
}
|
}
|
||||||
return (len);
|
return (len);
|
||||||
|
@ -3,16 +3,16 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* ft_putnbrbase.c :+: :+: :+: */
|
/* ft_putnbrbase.c :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/11/18 10:57:44 by adjoly #+# #+# */
|
/* Created: 2023/11/18 10:57:44 by adjoly #+# #+# */
|
||||||
/* Updated: 2023/11/22 14:02:37 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:21:56 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "ft_printf.h"
|
#include "ft_printf.h"
|
||||||
|
|
||||||
int ft_putnbrbase(unsigned int n, char *base)
|
int ft_putnbrbase_pf(unsigned int n, char *base)
|
||||||
{
|
{
|
||||||
unsigned int base_len;
|
unsigned int base_len;
|
||||||
int len;
|
int len;
|
||||||
@ -23,7 +23,7 @@ int ft_putnbrbase(unsigned int n, char *base)
|
|||||||
len += write(1, &base[n % base_len], 1);
|
len += write(1, &base[n % base_len], 1);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
len += ft_putnbrbase(n / base_len, base);
|
len += ft_putnbrbase_pf(n / base_len, base);
|
||||||
len += write(1, &base[n % base_len], 1);
|
len += write(1, &base[n % base_len], 1);
|
||||||
}
|
}
|
||||||
return (len);
|
return (len);
|
||||||
|
@ -3,16 +3,16 @@
|
|||||||
/* ::: :::::::: */
|
/* ::: :::::::: */
|
||||||
/* ft_putstr.c :+: :+: :+: */
|
/* ft_putstr.c :+: :+: :+: */
|
||||||
/* +:+ +:+ +:+ */
|
/* +:+ +:+ +:+ */
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2023/10/31 11:45:55 by adjoly #+# #+# */
|
/* Created: 2023/10/31 11:45:55 by adjoly #+# #+# */
|
||||||
/* Updated: 2023/11/20 15:51:38 by adjoly ### ########.fr */
|
/* Updated: 2024/02/04 15:23:52 by adjoly ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "ft_printf.h"
|
#include "ft_printf.h"
|
||||||
|
|
||||||
int ft_putstr(char *s)
|
int ft_putstr_p(char *s)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -22,10 +22,5 @@ int ft_putstr(char *s)
|
|||||||
write(1, "(null)", 6);
|
write(1, "(null)", 6);
|
||||||
return (6);
|
return (6);
|
||||||
}
|
}
|
||||||
while (s[i])
|
return (write(1, s, ft_strlen(s)));
|
||||||
{
|
|
||||||
write(1, &s[i], 1);
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
return (i);
|
|
||||||
}
|
}
|
||||||
|
@ -1,23 +0,0 @@
|
|||||||
/* ************************************************************************** */
|
|
||||||
/* */
|
|
||||||
/* ::: :::::::: */
|
|
||||||
/* ft_strlen.c :+: :+: :+: */
|
|
||||||
/* +:+ +:+ +:+ */
|
|
||||||
/* By: adjoly <adjoly@student.42.fr> +#+ +:+ +#+ */
|
|
||||||
/* +#+#+#+#+#+ +#+ */
|
|
||||||
/* Created: 2023/10/30 18:15:57 by adjoly #+# #+# */
|
|
||||||
/* Updated: 2023/11/20 15:51:51 by adjoly ### ########.fr */
|
|
||||||
/* */
|
|
||||||
/* ************************************************************************** */
|
|
||||||
|
|
||||||
#include "ft_printf.h"
|
|
||||||
|
|
||||||
size_t ft_strlen(const char *s)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
i = 0;
|
|
||||||
while (s[i])
|
|
||||||
i++;
|
|
||||||
return (i);
|
|
||||||
}
|
|
Reference in New Issue
Block a user