aboutsummaryrefslogtreecommitdiff
path: root/test_mini/libft/src/io/ft_printf/internals/convert_int.c
diff options
context:
space:
mode:
authornass1pro <nass1pro@gmail.com>2020-06-09 19:48:34 +0200
committernass1pro <nass1pro@gmail.com>2020-06-13 11:31:00 +0200
commit579a26f5593039ffbbd1a81e45ecf0ef8797cb5d (patch)
treec5b6761db98e27d15bab3fb45ba9e0a646cf06e0 /test_mini/libft/src/io/ft_printf/internals/convert_int.c
parent9fabc25a980550afc6337fd729632462f2680daa (diff)
downloadminishell-579a26f5593039ffbbd1a81e45ecf0ef8797cb5d.tar.gz
minishell-579a26f5593039ffbbd1a81e45ecf0ef8797cb5d.tar.bz2
minishell-579a26f5593039ffbbd1a81e45ecf0ef8797cb5d.zip
add lexer
add single quote
Diffstat (limited to 'test_mini/libft/src/io/ft_printf/internals/convert_int.c')
-rw-r--r--test_mini/libft/src/io/ft_printf/internals/convert_int.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/test_mini/libft/src/io/ft_printf/internals/convert_int.c b/test_mini/libft/src/io/ft_printf/internals/convert_int.c
new file mode 100644
index 0000000..2345f76
--- /dev/null
+++ b/test_mini/libft/src/io/ft_printf/internals/convert_int.c
@@ -0,0 +1,40 @@
+/* ************************************************************************** */
+/* */
+/* ::: :::::::: */
+/* convert_int.c :+: :+: :+: */
+/* +:+ +:+ +:+ */
+/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */
+/* +#+#+#+#+#+ +#+ */
+/* Created: 2019/10/30 23:29:53 by cacharle #+# #+# */
+/* Updated: 2019/11/06 00:00:09 by cacharle ### ########.fr */
+/* */
+/* ************************************************************************** */
+
+#include "ft_vasprintf.h"
+
+char *convert_int(va_list ap, t_pformat *pformat)
+{
+ int is_neg;
+ long long int n;
+ char *str;
+
+ n = length_modifier_int(ap, pformat);
+ is_neg = n < 0;
+ str = ITOA_DEC(n);
+ if (is_neg)
+ ft_strcpy(str, str + 1);
+ str = handle_precision(pformat, str);
+ if (pformat->flags & FLAG_ZERO)
+ {
+ if (is_neg || pformat->flags & (FLAG_SIGNED | FLAG_SPACE))
+ pformat->width--;
+ str = handle_width(pformat, str);
+ }
+ if (is_neg)
+ str = ft_strjoin_free_snd("-", str);
+ else if (pformat->flags & (FLAG_SIGNED | FLAG_SPACE))
+ str = ft_strjoin_free_snd(pformat->flags & FLAG_SPACE ? " " : "+", str);
+ if (!(pformat->flags & FLAG_ZERO))
+ str = handle_width(pformat, str);
+ return (str);
+}