diff options
author | JozanLeClerc <bousset.rudy@gmail.com> | 2020-04-19 22:27:11 +0200 |
---|---|---|
committer | JozanLeClerc <bousset.rudy@gmail.com> | 2020-04-19 22:27:11 +0200 |
commit | 62afe606a355581c5b48cca361478c43fb6ae4cf (patch) | |
tree | a278fe2fdf44c296892616554743b9d380ff7afa /libft/src/ft_printf_put_ptr.c | |
parent | Added joe-sh_history to gitignore (diff) | |
download | 42-minishell-62afe606a355581c5b48cca361478c43fb6ae4cf.tar.gz 42-minishell-62afe606a355581c5b48cca361478c43fb6ae4cf.tar.bz2 42-minishell-62afe606a355581c5b48cca361478c43fb6ae4cf.tar.xz 42-minishell-62afe606a355581c5b48cca361478c43fb6ae4cf.tar.zst 42-minishell-62afe606a355581c5b48cca361478c43fb6ae4cf.zip |
Well well well that wasn't too bad, now remake everything
Diffstat (limited to 'libft/src/ft_printf_put_ptr.c')
-rw-r--r-- | libft/src/ft_printf_put_ptr.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/libft/src/ft_printf_put_ptr.c b/libft/src/ft_printf_put_ptr.c new file mode 100644 index 0000000..bd50443 --- /dev/null +++ b/libft/src/ft_printf_put_ptr.c @@ -0,0 +1,42 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_printf_put_ptr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: rbousset <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2020/02/14 17:06:45 by rbousset #+# #+# */ +/* Updated: 2020/02/14 17:06:45 by rbousset ### ########lyon.fr */ +/* */ +/* ************************************************************************** */ + +#include <libft.h> +#include <stdlib.h> +#include <stdarg.h> +#include <inttypes.h> + +/* +** For GCC: if (!p) { ft_putstr("(nil)"); return ; } +*/ + +void + ft_printf_put_p(va_list arg, t_printflist *pflist) +{ + unsigned long p; + char *str; + + p = va_arg(arg, unsigned long); + pflist->conv = 'p'; + pflist->putlen += 2 + ft_uintlen_base(p, FT_MIN_HEX_BASE); + ft_printf_put_width_pre(pflist); + ft_printf_cat_output("0x", 2, pflist); + if (pflist->precision > pflist->putlen - 2) + ft_printf_put_precision(pflist); + if (!(pflist->precision < 0 && p == 0)) + { + str = ft_uitoa_base(p, FT_MIN_HEX_BASE); + ft_printf_cat_output(str, ft_strlen(str), pflist); + ft_memdel((void**)&str); + } + ft_printf_put_width_post(pflist); +} |