mirror of
https://github.com/DavidGailleton/42-ft_printf.git
synced 2026-04-28 14:24:34 +02:00
some fix on printf
This commit is contained in:
@@ -10,8 +10,8 @@
|
|||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include "ft_printf_bonus.h"
|
#include "ft_printf_bonus.h"
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
t_arg *ft_create_arg(void)
|
t_arg *ft_create_arg(void)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -12,8 +12,8 @@
|
|||||||
|
|
||||||
static int is_main_arg(char c)
|
static int is_main_arg(char c)
|
||||||
{
|
{
|
||||||
if (c == 'c' || c == 's' || c == 'p' || c == 'd'
|
if (c == 'c' || c == 's' || c == 'p' || c == 'd' || c == 'i' || c == 'u'
|
||||||
|| c == 'i' || c == 'u' || c == 'x' || c == 'X' || c == '%')
|
|| c == 'x' || c == 'X' || c == '%')
|
||||||
return (1);
|
return (1);
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -41,12 +41,12 @@ static void ft_parse_str(t_arg *arg, char *str, char main_arg)
|
|||||||
if (*str == '.')
|
if (*str == '.')
|
||||||
{
|
{
|
||||||
arg->dot = ft_atoi(str + 1);
|
arg->dot = ft_atoi(str + 1);
|
||||||
if (!(arg->minus >= 0 || arg->hash >= 0
|
if (!(arg->minus >= 0 || arg->hash >= 0 || arg->space >= 0
|
||||||
|| arg->space >= 0 || arg->plus >= 0))
|
|| arg->plus >= 0))
|
||||||
get_padding(arg, str);
|
get_padding(arg, str);
|
||||||
}
|
}
|
||||||
else if (!(arg->minus >= 0 || arg->hash >= 0
|
else if (!(arg->minus >= 0 || arg->hash >= 0 || arg->space >= 0
|
||||||
|| arg->space >= 0 || arg->plus >= 0))
|
|| arg->plus >= 0))
|
||||||
get_padding(arg, str);
|
get_padding(arg, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
+18
-11
@@ -71,6 +71,16 @@ static int ft_to_skip(char *str)
|
|||||||
return (count);
|
return (count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int handle_arg(const char *s, va_list args, int *i)
|
||||||
|
{
|
||||||
|
int n;
|
||||||
|
|
||||||
|
(*i)++;
|
||||||
|
n = ft_print_arg((char *)&s[*i], args);
|
||||||
|
*i += ft_to_skip((char *)&s[*i]);
|
||||||
|
return (n);
|
||||||
|
}
|
||||||
|
|
||||||
int ft_printf(const char *first_arg, ...)
|
int ft_printf(const char *first_arg, ...)
|
||||||
{
|
{
|
||||||
va_list args;
|
va_list args;
|
||||||
@@ -78,23 +88,20 @@ int ft_printf(const char *first_arg, ...)
|
|||||||
int i;
|
int i;
|
||||||
int temp;
|
int temp;
|
||||||
|
|
||||||
|
if (!first_arg)
|
||||||
|
return (-1);
|
||||||
nb_print = 0;
|
nb_print = 0;
|
||||||
|
i = -1;
|
||||||
va_start(args, first_arg);
|
va_start(args, first_arg);
|
||||||
i = 0;
|
while (first_arg[++i])
|
||||||
while (first_arg[i])
|
|
||||||
{
|
{
|
||||||
temp = nb_print;
|
temp = nb_print;
|
||||||
if (first_arg[i] == '%' && first_arg[i + 1] != '\0')
|
if (first_arg[i] == '%' && first_arg[i + 1])
|
||||||
{
|
nb_print += handle_arg(first_arg, args, &i);
|
||||||
i++;
|
else if (first_arg[i] != '%')
|
||||||
nb_print += ft_print_arg((char *)&first_arg[i], args);
|
|
||||||
i += ft_to_skip((char *)&first_arg[i]);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
nb_print += write(1, &first_arg[i], 1);
|
nb_print += write(1, &first_arg[i], 1);
|
||||||
if (temp > nb_print)
|
if (temp >= nb_print)
|
||||||
return (-1);
|
return (-1);
|
||||||
i++;
|
|
||||||
}
|
}
|
||||||
va_end(args);
|
va_end(args);
|
||||||
return (nb_print);
|
return (nb_print);
|
||||||
|
|||||||
@@ -40,8 +40,8 @@ int ft_putnbr_base(unsigned int nbr, char *base, int base_size, int limit)
|
|||||||
return (ft_putnbr_base_extra(nbr, base, base_size));
|
return (ft_putnbr_base_extra(nbr, base, base_size));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int ft_putnbr_base_ll_extra(unsigned long long nbr
|
static int ft_putnbr_base_ll_extra(unsigned long long nbr, char *base,
|
||||||
, char *base, int base_size)
|
int base_size)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
char temp;
|
char temp;
|
||||||
|
|||||||
@@ -15,7 +15,7 @@
|
|||||||
|
|
||||||
int print_char(t_arg *arg, char c)
|
int print_char(t_arg *arg, char c)
|
||||||
{
|
{
|
||||||
int count;
|
int count;
|
||||||
|
|
||||||
count = 0;
|
count = 0;
|
||||||
count += print_chars(arg->padding - 1, ' ');
|
count += print_chars(arg->padding - 1, ' ');
|
||||||
|
|||||||
@@ -10,8 +10,8 @@
|
|||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "libft.h"
|
|
||||||
#include "ft_printf_bonus.h"
|
#include "ft_printf_bonus.h"
|
||||||
|
#include "libft.h"
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
int print_pointer(t_arg *arg, unsigned long long p)
|
int print_pointer(t_arg *arg, unsigned long long p)
|
||||||
|
|||||||
@@ -10,8 +10,8 @@
|
|||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "libft.h"
|
|
||||||
#include "ft_printf_bonus.h"
|
#include "ft_printf_bonus.h"
|
||||||
|
#include "libft.h"
|
||||||
|
|
||||||
int print_str(t_arg *arg, char *str)
|
int print_str(t_arg *arg, char *str)
|
||||||
{
|
{
|
||||||
@@ -28,7 +28,7 @@ int print_str(t_arg *arg, char *str)
|
|||||||
return (-10000);
|
return (-10000);
|
||||||
return (count + 6);
|
return (count + 6);
|
||||||
}
|
}
|
||||||
if (arg->dot > (int) ft_strlen(str) || arg->dot < 0)
|
if (arg->dot > (int)ft_strlen(str) || arg->dot < 0)
|
||||||
arg->dot = ft_strlen(str);
|
arg->dot = ft_strlen(str);
|
||||||
if (arg->padding > 0)
|
if (arg->padding > 0)
|
||||||
count += print_chars(arg->padding - arg->dot, ' ');
|
count += print_chars(arg->padding - arg->dot, ' ');
|
||||||
|
|||||||
@@ -13,6 +13,7 @@
|
|||||||
#ifndef FT_PRINTF_H
|
#ifndef FT_PRINTF_H
|
||||||
# define FT_PRINTF_H
|
# define FT_PRINTF_H
|
||||||
|
|
||||||
|
int ft_printf(const char *first_arg, ...) __attribute__((format(printf, 1, 2)));
|
||||||
int ft_printf(const char *first_arg, ...);
|
int ft_printf(const char *first_arg, ...);
|
||||||
|
|
||||||
int ft_putnbr_base(unsigned long long nbr, char *base, int base_size);
|
int ft_putnbr_base(unsigned long long nbr, char *base, int base_size);
|
||||||
|
|||||||
+19
-15
@@ -23,23 +23,27 @@ typedef struct s_arg
|
|||||||
int hash;
|
int hash;
|
||||||
int space;
|
int space;
|
||||||
int plus;
|
int plus;
|
||||||
} t_arg;
|
} t_arg;
|
||||||
|
|
||||||
int ft_printf(const char *first_arg, ...);
|
int ft_printf(const char *first_arg, ...) __attribute__((format(printf,
|
||||||
|
1, 2)));
|
||||||
|
int ft_printf(const char *first_arg, ...);
|
||||||
|
|
||||||
int ft_putnbr_base_ll(unsigned long long nbr, char *base, int base_size);
|
int ft_putnbr_base_ll(unsigned long long nbr, char *base,
|
||||||
int ft_putnbr_base(unsigned int nbr, char *base, int base_size, int limit);
|
int base_size);
|
||||||
char ft_main_arg(char *str);
|
int ft_putnbr_base(unsigned int nbr, char *base, int base_size,
|
||||||
t_arg *ft_create_arg(void);
|
int limit);
|
||||||
t_arg *ft_parsing(char *str);
|
char ft_main_arg(char *str);
|
||||||
int print_chars(int nb, char c);
|
t_arg *ft_create_arg(void);
|
||||||
int nbr_size_base(unsigned long long nb, int base_size);
|
t_arg *ft_parsing(char *str);
|
||||||
|
int print_chars(int nb, char c);
|
||||||
|
int nbr_size_base(unsigned long long nb, int base_size);
|
||||||
|
|
||||||
int print_char(t_arg *arg, char c);
|
int print_char(t_arg *arg, char c);
|
||||||
int print_str(t_arg *arg, char *str);
|
int print_str(t_arg *arg, char *str);
|
||||||
int print_pointer(t_arg *arg, unsigned long long p);
|
int print_pointer(t_arg *arg, unsigned long long p);
|
||||||
int print_number(t_arg *arg, int nbr);
|
int print_number(t_arg *arg, int nbr);
|
||||||
int print_unsigned(t_arg *arg, unsigned int nbr);
|
int print_unsigned(t_arg *arg, unsigned int nbr);
|
||||||
int print_hex(t_arg *arg, unsigned int nbr);
|
int print_hex(t_arg *arg, unsigned int nbr);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
+6
-5
@@ -42,10 +42,12 @@ int ft_printf(const char *first_arg, ...)
|
|||||||
int i;
|
int i;
|
||||||
int temp;
|
int temp;
|
||||||
|
|
||||||
|
if (!first_arg)
|
||||||
|
return (-1);
|
||||||
nb_print = 0;
|
nb_print = 0;
|
||||||
va_start(args, first_arg);
|
va_start(args, first_arg);
|
||||||
i = 0;
|
i = -1;
|
||||||
while (first_arg[i])
|
while (first_arg[++i])
|
||||||
{
|
{
|
||||||
temp = nb_print;
|
temp = nb_print;
|
||||||
if (first_arg[i] == '%' && first_arg[i + 1] != '\0')
|
if (first_arg[i] == '%' && first_arg[i + 1] != '\0')
|
||||||
@@ -53,11 +55,10 @@ int ft_printf(const char *first_arg, ...)
|
|||||||
i++;
|
i++;
|
||||||
nb_print += ft_print_arg(first_arg[i], args);
|
nb_print += ft_print_arg(first_arg[i], args);
|
||||||
}
|
}
|
||||||
else
|
else if (first_arg[i] != '%')
|
||||||
nb_print += write(1, &first_arg[i], 1);
|
nb_print += write(1, &first_arg[i], 1);
|
||||||
if (temp > nb_print)
|
if (temp >= nb_print)
|
||||||
return (-1);
|
return (-1);
|
||||||
i++;
|
|
||||||
}
|
}
|
||||||
va_end(args);
|
va_end(args);
|
||||||
return (nb_print);
|
return (nb_print);
|
||||||
|
|||||||
+1
-1
@@ -10,8 +10,8 @@
|
|||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
#include "libft.h"
|
|
||||||
#include "ft_printf.h"
|
#include "ft_printf.h"
|
||||||
|
#include "libft.h"
|
||||||
|
|
||||||
int print_pointer(unsigned long long p)
|
int print_pointer(unsigned long long p)
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user