Merge branch 'charpoopoo' of github.com:LinlyBoi/printf into charpoopoo

This commit is contained in:
LinlyBoi
2023-08-22 14:03:57 +03:00
4 changed files with 50 additions and 13 deletions

1
main.h
View File

@@ -6,5 +6,6 @@ int _strlen(const char *str);
char *_strcpy(char *dest, char *src); char *_strcpy(char *dest, char *src);
char *append(char *str, char c); char *append(char *str, char c);
void _puts(char *str); void _puts(char *str);
char* _memset(char *str, int bval);
#endif #endif

22
memset.c Normal file
View File

@@ -0,0 +1,22 @@
#include "main.h"
/**
* _memset - sets values of bytes to specific value
*
* @adr: head address
* @n: number of bytes
*
* Return: pointer to place
*/
char* _memset(char *str, int bval)
{
int i;
for (i = 0; i < _strlen(str); i++)
{
*(str + i) = bval;
}
return (str);
}

View File

@@ -19,7 +19,7 @@ int _printf(const char *format, ...)
va_start(args, format); va_start(args, format);
identifiers = _contains(format, '%'); identifiers = _contains(format, '%');
BUFF_SIZE = _strlen(format) - (identifiers * 2); BUFF_SIZE = _strlen(format) - identifiers;
buffer = malloc(BUFF_SIZE); buffer = malloc(BUFF_SIZE);
if (!format) /* No string. No laundry */ if (!format) /* No string. No laundry */
@@ -28,32 +28,46 @@ int _printf(const char *format, ...)
{ {
if ((*(format + fmt_idx) == '%') && (*(format + fmt_idx + 1))) if ((*(format + fmt_idx) == '%') && (*(format + fmt_idx + 1)))
{ {
switch (*(format + 1)) /*this needs to shrink*/ if (*buffer)
{
_puts(buffer);
free(buffer);
buffer = malloc(BUFF_SIZE);
buff_idx = 0;
}
switch (*(format + fmt_idx + 1)) /*this needs to shrink*/
{ {
case 's': case 's':
next = va_arg(args, char*); /*Store string temporarily*/ next = va_arg(args, char*); /*Store string temporarily*/
buffer = _strcpy(buffer, next); write(1, next, _strlen(next));
BUFF_SIZE = _strlen(buffer);
buff_idx += _strlen(next);
break; break;
case 'c': /* add 1 byte and i++ */ case 'c': /* add 1 byte and i++ */
c = (char) va_arg(args, int); c = va_arg(args, int);
buffer = append(buffer, c); write(1, &c, 1);
BUFF_SIZE += 1;
buff_idx += 1;
break; break;
case '%': /*add 1 byte*/ case '%': /*add 1 byte*/
break; break;
} }
if (*(format + fmt_idx + 2))
{
fmt_idx += 2; fmt_idx += 2;
} }
else else
{
fmt_idx += 1;
}
}
else
{ {
*(buffer + buff_idx) = *(format + fmt_idx); *(buffer + buff_idx) = *(format + fmt_idx);
buff_idx++; buff_idx++;
fmt_idx++; fmt_idx++;
} }
} }
write(1, buffer, BUFF_SIZE + 1); if (*buffer)
{
_puts(buffer);
free(buffer);
}
return (_strlen(buffer)); return (_strlen(buffer));
} }

View File

@@ -8,9 +8,9 @@
int main(void) int main(void)
{ {
char c = 'c'; char c = 97;
_printf("%c%c", c, c); _printf("%c%c\n", c, c);
_printf("cat: %c\n", c); _printf("cat: %c\n", c);
return (0); return (0);
} }