diff options
| author | Charles <sircharlesaze@gmail.com> | 2019-11-21 02:53:41 +0100 |
|---|---|---|
| committer | Charles <sircharlesaze@gmail.com> | 2019-11-21 04:03:13 +0100 |
| commit | ee4b8e5e481850c936c5df10a0d3e70038234754 (patch) | |
| tree | 5e569b3ebc2bdcafdbd06fef99f32207da29d4ee /ft_printf/length_modifier.c | |
| parent | afc8c70a66773563f6e7429b500abcbab631722b (diff) | |
| download | libft-ee4b8e5e481850c936c5df10a0d3e70038234754.tar.gz libft-ee4b8e5e481850c936c5df10a0d3e70038234754.tar.bz2 libft-ee4b8e5e481850c936c5df10a0d3e70038234754.zip | |
WIP: adding ft_*printf
Diffstat (limited to 'ft_printf/length_modifier.c')
| -rw-r--r-- | ft_printf/length_modifier.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/ft_printf/length_modifier.c b/ft_printf/length_modifier.c new file mode 100644 index 0000000..88226da --- /dev/null +++ b/ft_printf/length_modifier.c @@ -0,0 +1,39 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* length_modifier.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: cacharle <marvin@42.fr> +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2019/11/05 23:56:07 by cacharle #+# #+# */ +/* Updated: 2019/11/09 00:50:06 by cacharle ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "ft_vasprintf.h" + +t_big_uint length_modifier_unsigned_int(va_list ap, t_pformat *pformat) +{ + if (pformat->flags & FLAG_SHORT) + return ((unsigned short)va_arg(ap, int)); + else if (pformat->flags & FLAG_SHORT_SHORT) + return ((unsigned char)va_arg(ap, int)); + else if (pformat->flags & FLAG_LONG) + return (va_arg(ap, long unsigned int)); + else if (pformat->flags & FLAG_LONG_LONG) + return (va_arg(ap, long long unsigned int)); + return (va_arg(ap, unsigned int)); +} + +t_big_int length_modifier_int(va_list ap, t_pformat *pformat) +{ + if (pformat->flags & FLAG_SHORT) + return ((short)va_arg(ap, int)); + else if (pformat->flags & FLAG_SHORT_SHORT) + return ((signed char)va_arg(ap, int)); + else if (pformat->flags & FLAG_LONG) + return (va_arg(ap, long int)); + else if (pformat->flags & FLAG_LONG_LONG) + return (va_arg(ap, long long int)); + return (va_arg(ap, int)); +} |
