ecriture tests var_arg

This commit is contained in:
Hugo LAMY
2020-01-06 17:27:04 +01:00
parent 40a409963d
commit b3ef54c38b
2 changed files with 111 additions and 47 deletions

View File

@@ -1,34 +1,83 @@
#include "ft_printf.h"
// %[arg_nbr$][flags][][width][.precision][length]specifier //#include "ft_printf.h"
#include <libc.h>
int ft_printf(char *fmt, ...) typedef unsigned char *ta_list;
#define ta_start(list, param) (list = (((ta_list)&param) + sizeof(param)))
#define ta_arg(list, type) (*(type *)((list += sizeof(type)) - sizeof(type)))
//int ft_printf(char *string, ...)
int ft_printf(int num, ...)
{ {
va_list ap; // ta_list ap;
int d; char *arg;
char c, *s; // int d;
// char c;
// char *s;
va_start(ap, fmt); arg = (char *)&num;
while (*fmt != '\0') arg++;
printf("%s\n", arg);
/* while (*arg != '\0')
arg++;
arg += 1;
//arg = (((char*)&string) + sizeof(string));
//ta_start(ap, string);
while (*string != '\0')
{ {
if (*fmt == 's') if (*string == 's')
{ {
s = va_arg(ap, char *); //s = ta_arg(ap, char *);
printf("string %s\n", s); s = (char *)arg;
printf("string '%s'\n", s);
// while (*arg != '\0')
// {
// printf(" '%1$i%1$c' ", *arg);
// arg++;
// }
// printf(" '%1$i%1$c' ", *arg);
arg += sizeof(char *);
// printf(" '%1$i%1$c' \n", *arg);
//arg += sizeof(char *);
} }
if (*fmt == 'd') if (*string == 'd')
{ {
d = va_arg(ap, int); //d = ta_arg(ap, int);
d = (int)(*arg);
printf("int %d\n", d); printf("int %d\n", d);
} }
if (*fmt == 'c') if (*string == 'c')
{ {
c = va_arg(ap, int); //c = ta_arg(ap, int);
printf("char %c\n", c); //c = (char)(*arg);
printf("char %s\n", arg);
} }
fmt++; string++;
} }*/
va_end(ap);
// va_list ap;
//
// va_start(ap, string);
// while (*string != '\0')
// {
// if (*string == 's')
// {
// s = va_arg(ap, char *);
// printf("string %s\n", s);
// }
// if (*string == 'd')
// {
// d = va_arg(ap, int);
// printf("int %d\n", d);
// }
// if (*string == 'c')
// {
// c = va_arg(ap, int);
// printf("char %c\n", c);
// }
// string++;
// }
// va_end(ap);
return (0); return (0);
} }
@@ -39,20 +88,21 @@ int main(void)
char c; char c;
int i; int i;
s = "scd"; s = "csd";
c = 'p';
str = "bravo"; str = "bravo";
c = 'c';
i = 6; i = 6;
ft_printf(s, str, c, i); printf("%s-%s-%c-%i\n\n", s, str, c, i);
ft_printf(4, s, c, str, i);
return (0); return (0);
} }
/* /*
conversions : cspdiuxX% conversions : cspdiuxX%
flags : -,0,.,* flags : - 0 . *
conversions : nfge conversions : nfge
flags : l,ll,h,hh,#,', ,+ flags : l ll h hh # ' (space) +
%[arg_nbr$][flags 0,-,#,', ,+][width *][.precision *][length hh,h,ll,l,L,j,t,z][specifier d,i,u,x,X,c,s,p,%,e,f,g,n,E,F,G,a,A,C,S,o] %[arg_nbr$][flags 0,-,#,', ,+][width *][.precision *][length hh,h,ll,l,L,j,t,z][specifier d,i,u,x,X,c,s,p,%,e,f,g,n,E,F,G,a,A,C,S,o]
% [flags 0,- ][width *][.precision *] [specifier d,i,u,x,X,c,s,p,% ] % [flags 0,- ][width *][.precision *] [specifier d,i,u,x,X,c,s,p,% ]
@@ -62,38 +112,39 @@ typedef struct s_prist
{ {
int print_nbr; int print_nbr;
int arg_nbr; int arg_nbr;
char specifier; int flag; //[0-#' +*] binary
int flag; //['0','-','#',''',' ','+','*'] binary
int width; int width;
int precision; int precision;
char *length;
char specifier;
char *arg; char *arg;
struct s_prist *next; struct s_prist *next;
} t_prist; } t_prist;
("2 1 3 4 3", 1, 2, 3, 4) ("2 1 3 4 3", 1, 2, 3, 4)
store ft_store
{{printf_nbr 1; arg_nbr 2; specifier; flag; width; precision}, for each : ft_check_error
{printf_nbr 2; arg_nbr 1; specifier; flag; width; precision}, {{printf_nbr 1; arg_nbr 2; flag; width; precision; length; specifier},
{printf_nbr 3; arg_nbr 3; specifier; flag; width; precision}, {printf_nbr 2; arg_nbr 1; flag; width; precision; length; specifier},
{printf_nbr 4; arg_nbr 4; specifier; flag; width; precision}, {printf_nbr 3; arg_nbr 3; flag; width; precision; length; specifier},
{printf_nbr 5; arg_nbr 3; specifier; flag; width; precision}} {printf_nbr 4; arg_nbr 4; flag; width; precision; length; specifier},
{printf_nbr 5; arg_nbr 3; flag; width; precision; length; specifier}}
check_more_error ft_sort_by_arg
{{printf_nbr 2; arg_nbr 1; flag; width; precision; length; specifier},
{printf_nbr 1; arg_nbr 2; flag; width; precision; length; specifier},
{printf_nbr 3; arg_nbr 3; flag; width; precision; length; specifier},
{printf_nbr 5; arg_nbr 3; flag; width; precision; length; specifier},
{printf_nbr 4; arg_nbr 4; flag; width; precision; length; specifier}}
sort_by_arg ft_add_arg
{{printf_nbr 2; arg_nbr 1; specifier; flag; width; precision},
{printf_nbr 1; arg_nbr 2; specifier; flag; width; precision},
{printf_nbr 3; arg_nbr 3; specifier; flag; width; precision},
{printf_nbr 5; arg_nbr 3; specifier; flag; width; precision},
{printf_nbr 4; arg_nbr 4; specifier; flag; width; precision}}
add_str_to_print
if flag == * >> rerun for next argument but same list element if flag == * >> rerun for next argument but same list element
{{printf_nbr 2; arg_nbr 1; specifier; flag; width; precision; arg}, if lst->next->arg == lst->arg rerun for next list element but same argument
{printf_nbr 1; arg_nbr 2; specifier; flag; width; precision; arg}, {{printf_nbr 2; arg_nbr 1; flag; width; precision; length; specifier; arg},
{printf_nbr 3; arg_nbr 3; specifier; flag; width; precision; arg}, {printf_nbr 1; arg_nbr 2; flag; width; precision; length; specifier; arg},
{printf_nbr 5; arg_nbr 3; specifier; flag; width; precision; arg}, {printf_nbr 3; arg_nbr 3; flag; width; precision; length; specifier; arg},
{printf_nbr 4; arg_nbr 4; specifier; flag; width; precision; arg}} {printf_nbr 5; arg_nbr 3; flag; width; precision; length; specifier; arg},
{printf_nbr 4; arg_nbr 4; flag; width; precision; length; specifier; arg}}
*/ */

View File

@@ -4,6 +4,19 @@
# include <stdio.h> # include <stdio.h>
# include <stdarg.h> # include <stdarg.h>
int ft_printf(char *fmt, ...); int ft_printf(char *string, ...);
typedef struct s_prist
{
int print_nbr;
int arg_nbr;
int flag;
int width;
int precision;
char *length;
char specifier;
char *arg;
struct s_prist *next;
} t_prist;
#endif #endif