summaryrefslogtreecommitdiffstats
path: root/libft/src/ft_printf_put_ptr.c
diff options
context:
space:
mode:
authorJozanLeClerc <bousset.rudy@gmail.com>2020-04-19 22:27:11 +0200
committerJozanLeClerc <bousset.rudy@gmail.com>2020-04-19 22:27:11 +0200
commit62afe606a355581c5b48cca361478c43fb6ae4cf (patch)
treea278fe2fdf44c296892616554743b9d380ff7afa /libft/src/ft_printf_put_ptr.c
parentAdded joe-sh_history to gitignore (diff)
download42-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.c42
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);
+}