ft_substr: don't allocate too much mem + handle start outside of str
This commit is contained in:
parent
29f2cc104a
commit
26618f40b1
1 changed files with 24 additions and 2 deletions
26
ft_substr.c
26
ft_substr.c
|
|
@ -6,18 +6,39 @@
|
|||
/* By: kcolin <marvin@42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2024/10/17 11:45:52 by kcolin #+# #+# */
|
||||
/* Updated: 2024/10/17 11:58:18 by kcolin ### ########.fr */
|
||||
/* Updated: 2024/10/19 18:34:36 by kcolin ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "libft.h"
|
||||
#include <stdlib.h>
|
||||
|
||||
static int min(size_t a, size_t b)
|
||||
{
|
||||
if (a > b)
|
||||
return (b);
|
||||
return (a);
|
||||
}
|
||||
|
||||
char *ft_substr(char const *s, unsigned int start, size_t len)
|
||||
{
|
||||
char *out;
|
||||
size_t substr_len;
|
||||
size_t i;
|
||||
|
||||
out = malloc(sizeof(char) * len + 1);
|
||||
substr_len = 0;
|
||||
i = 0;
|
||||
while (s[i] != '\0')
|
||||
{
|
||||
if (i >= start)
|
||||
substr_len++;
|
||||
if (i >= start + len)
|
||||
break ;
|
||||
i++;
|
||||
}
|
||||
if (i < start)
|
||||
return (ft_calloc(1, sizeof(char)));
|
||||
out = ft_calloc(min(substr_len + 1, len + 1), sizeof(char));
|
||||
if (out == NULL)
|
||||
return (NULL);
|
||||
ft_strlcpy(out, s + start, len + 1);
|
||||
|
|
@ -35,5 +56,6 @@ int main(void)
|
|||
printf("'%s'\n", ft_substr(data, 15, 4));
|
||||
printf("'%s'\n", ft_substr(data, 15, 0));
|
||||
printf("'%s'\n", ft_substr(data, 20, 20));
|
||||
printf("'%s'\n", ft_substr(data, 100, 27));
|
||||
}
|
||||
*/
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue