brain dying pls
This commit is contained in:
1
main.h
1
main.h
@@ -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
22
memset.c
Normal 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);
|
||||||
|
}
|
||||||
34
printf.c
34
printf.c
@@ -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));
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user