Skip to content

mimarque/libft

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 

Repository files navigation

Libft

Version: 15

Based on vvarodi's and appinha's README.md


Index

Main Bonus
ft_atoi.c ft_lstadd_back.c
ft_bzero.c ft_lstadd_front.c
ft_calloc.c ft_lstclear.c
ft_isalnum.c ft_lstdelone.c
ft_isalpha.c ft_lstiter.c
ft_isascii.c ft_lstlast.c
ft_isdigit.c ft_lstmap.c
ft_isprint.c ft_lstnew.c
ft_isspace.c ft_lstpenultimate.c
ft_itoa.c ft_lstsize.c
ft_memccpy.c
ft_memchr.c
ft_memcmp.c
ft_memcpy.c
ft_memmove.c
ft_memset.c
ft_putchar_fd.c
ft_putendl_fd.c
ft_putnbr_fd.c
ft_putstr_fd.c
ft_split.c
ft_strchr.c
ft_strdup.c
ft_strjoin.c
ft_strlcat.c
ft_strlcpy.c
ft_strlen.c
ft_strmapi.c
ft_strncmp.c
ft_strnstr.c
ft_strrchr.c
ft_strtrim.c
ft_substr.c
ft_tolower.c
ft_toupper.c
Extra
ft_striteri.c
ft_strpbrk.c
ft_substrpbrk.c
ft_printf.c
get_next_line.c

Small description

Functions from <ctype.h>

Functions from <stdlib.h> library

Functions from <strings.h> library

Functions from <string.h> library

  • ft_strcat * - concatenate strings (s2 into s1).
  • ft_strchr - locate character in string (first occurrence).
  • ft_strcmp * - compare strings.
  • ft_strcpy * - copy strings.
  • ft_strdup - save a copy of a string (with malloc).
  • ft_strlcat - size-bounded string concatenation.
  • ft_strlcpy - size-bounded string copying.
  • ft_strlen - find length of string.
  • ft_strncat * - concatenate strings (s2 into s1, size-bounded).
  • ft_strncmp - compare strings (size-bounded).
  • ft_strndup * - save a copy of a string (with malloc, size-bounded).
  • ft_strncpy * - copy strings (size-bounded).
  • ft_strnrcmp - reversely compare strings (size-bounded).
  • ft_strnstr - locate a substring in a string (size-bounded).
  • ft_strrchr - locate character in string (last occurrence).
  • ft_strstr * - locate a substring in a string.

Non-standard functions

  • ft_itoa - convert integer to ASCII string.
  • ft_putchar_fd - output a character to given file.
  • ft_putendl_fd - output string to given file with newline.
  • ft_putnbr_fd - output integer to given file.
  • ft_putstr_fd - output string to given file.
  • ft_split - split string, with specified character as delimiter, into an array of strings.
  • ft_delete_split_arr * - free splitted string.
  • ft_strjoin - concatenate two strings into a new string (with malloc).
  • ft_strmapi - create new string from modifying string with specified function.
  • ft_strtrim - trim beginning and end of string with the specified characters.
  • ft_substr - extract substring from string.

Linked list functions

Full description

Functions from <ctype.h>:

int ft_isalnum(int c)

Description Param. #1 Return Value
Check for an alphanumeric character; it is equivalent to (ft_isalpha or ft_isdigit) The character to test 0 if the character tests false and 1 if the character tests true

int ft_isalpha(int c)

Description Param. #1 Return Value
Check for a alpabetic character, it is equivalent to (ft_isupper(c) or ft_islower(c)) The character to test 0 if the character tests false and 1 if the character tests true

int ft_isascii(int c)

Description Param. #1 Return Value
Checks for an ASCII character, which is any character between 0 and octal 0177 inclusive The character to test 0 if the character tests false and 1 if the character tests true

int ft_isdigit(int c)

Description Param. #1 Return Value
Check for a digit (0 through 9) The character to test 0 if the character tests false and 1 if the character tests true

int ft_isprint(int c)

Description Param. #1 Return Value
Checks for any printable character including space The character to test 0 if the character tests false and 1 if the character tests true

int ft_isspace(int c)

Description Param. #1 Return Value
Checks for white-space characters. These are: space, form-feed ('\f'), newline ('\n'), carriage return('\r'), horizontal tab ('\t'), and vertical tab ('\v'). The character to test 0 if the character tests false and 1 if the character tests true

int ft_tolower(int c)

Description Param. #1 Return Value
If the character passed as an argument is an uppercase, convert to lower The character to convert If c is a uppercase letter, returns its lowercase equivalent. Otherwise, it returns c.

int ft_toupper(int c)

Description Param. #1 Return Value
If the character passed as an argument is a lowercase, convert to upper The character to convert If c is a lowercase letter, returns its uppercase equivalent. Otherwise, it returns c.

Functions from <stdlib.h>:

int ft_atoi(const char *str)

Description Param. #1 Return Value
Convert a string to a integer The string to be converted to int The converted value

void *ft_calloc(size_t count, size_t size)

Description Param. #1 Param. #2 Return Value
Allocates enough space for count objects that are size bytes of memory each, and returns a pointer to the allocated memory. The allocated memory is filled with bytes of value zero Number of elements to be allocated Size of elements A pointer to the allocated memory, or NULL if the request fails

ft_itoa (extra)

char ft_itoa(int n)

Description Param. #1 Return Value
Allocates (with malloc) and returns a string representing the integer received as an argument. Negative numbers must be handled The integer to convert The string representing the integer. NULL if the allocation fails.

Functions from <string.h>:

char *ft_strchr(const char *s, int c)

Description Param. #1 Param. #2 Return Value
Locates the first occurrence of 'c' in the string pointed to by 's'. The terminating null character is considered to be part of the string, therefore if 'c' is '\0', locates the terminating '\0' Pointer to string Character to be located A pointer to the first occurrence of the character c in the string or NULL if the character is not found

char *ft_strdup(const char *s))

Description Param. #1 Return Values
Duplicate string s1. Memory for the new string is obtained with malloc, and can be freed with free The string to duplicate A pointer to the duplicated string. NULL if insufficient memory was available

size_t ft_strlcat(char *dst, const char *src, size_t size)

Description Param. #1 Param. #2 Param. #3 Return Value
Concatenate the string src to the end of dst. It will concatenate at most size - strlen(dst) - 1 bytes, NUL-terminating the result Destination array String to be appended to dst Maximum number of characters to be appended The initial length of dst plus the length of src

size_t ft_strlcpy(char *dst, const char *src, size_t dstsize)

Description Param. #1 Param. #2 Param. #3 Return Value
Copies up to dstsize - 1 characters from the NUL-terminated string src to dst, NUL-terminating the result Destination array String to be copied Number of characters to be copied from src Total length of the string to create (length of src)

size_t ft_strlen(const char *s)

Description Param. #1 Return Values
Calculates the length of the string pointed to by s, excluding the terminating null byte ('\0') The string to calculate Number of characters in the string pointed to by s

int strncmp(const char *s1, const char *s2, size_t n);

Description Param. #1 Param. #2 Param. #3 Return Value
The strncmp() function compares not more than n characters. Because strncmp() is designed for comparing strings rather than binary data, characters that appear after a ‘\0’ character are not compared. String 1 String 2 size to compare The strcmp() and strncmp() functions return an integer greater than, equal to, or less than 0, according as the string s1 is greater than, equal to, or less than the string s2. The comparison is done using unsigned characters, so that ‘\200’ is greater than ‘\0’.

char *ft_strnstr(const char *haystack, const char *needle, size_t len)

Description Param. #1 Param. #2 Param. #3 Return Value
Locate substring, where not more than 'len' characters are searched. Finds the first occurrence of the substring 'needle' in the string 'haystack'. The terminating null bytes ('\0') are not compared. String to be scanned The small string to be searched in 'haystack' string The maximum amount of characters to be searched A pointer to the first character of the first occurrence of little is returned. NULL if the substring is not found. If 'needle' is an empty string, 'haystack' is returned

char *ft_strrchr(const char *s, int c)

Description Param. #1 Param. #2 Return Value
Locates the last occurrence of 'c' in the string pointed to by 's'. The terminating null character is considered to be part of the string, therefore if 'c' is '\0', locates the terminating '\0' Pointer to string Character to be located A pointer to the last occurrence of the character c in the string or NULL if the character is not found

char *strstr(const char *haystack, const char *needle)

Description Param. #1 Param. #2 Return Value
Locates the first occurrence of the null-terminated string needle in the string haystack. The terminating null characters are not compared. The string to search The string to find A pointer to the beginning of the located substring, or NULL if the substring is not found

int strcmp(const char *s1, const char *s2)

Description Param. #1 Param. #2 Return Value
Compares the null-terminated strings s1 and s2. It compares character by character until a difference is found or the end of the strings is reached. The first string to compare The second string to compare An integer greater than, equal to, or less than 0, according to whether s1 is greater than, equal to, or less than s2

int strnrcmp(const char *s1, const char *s2, size_t n)

Description Param. #1 Param. #2 Param. #3 Return Value
Compares up to n characters of the strings s1 and s2, starting from the end of the strings. The first string to compare The second string to compare The number of characters to compare An integer greater than, equal to, or less than 0, according to whether s1 is greater than, equal to, or less than s2

char *strcpy(char *dst, const char *src)

Description Param. #1 Param. #2 Return Value
Copies the null-terminated string src to dst (including the null terminator). The destination buffer The source string A pointer to the destination string dst

char *strncpy(char *dst, const char *src, size_t n)

Description Param. #1 Param. #2 Param. #3 Return Value
Copies up to n characters from the string src to dst. If src is less than n characters long, the remainder of dst is padded with null bytes. The destination buffer The source string The number of characters to copy A pointer to the destination string dst

char *strndup(const char *s, size_t n)

Description Param. #1 Param. #2 Return Value
Allocates memory and duplicates up to n characters from the string s, null-terminating the result. The string to duplicate The number of characters to duplicate A pointer to the newly allocated string, or NULL if the allocation fails

char *strcat(char *dst, const char *src)

Description Param. #1 Param. #2 Return Value
Appends the null-terminated string src to the end of the null-terminated string dst. The terminating null byte of dst is overwritten by the first character of src, and a new null byte is added at the end of the concatenated string. The destination buffer The source string A pointer to the resulting string dst

char *strncat(char *dst, const char *src, size_t n)

Description Param. #1 Param. #2 Param. #3 Return Value
Appends up to n characters from the string src to the end of the null-terminated string dst, null-terminating the result. The destination buffer The source string The number of characters to append A pointer to the resulting string dst

Functions from <strings.h>:

void *ft_bzero(void *s, size_t n)

Description Param. #1 Param. #2 Return Value
Erases the data in the "n" bytes of the memory starting at the location pointed by "s" writing zeroes The string on which to operate The number of bytes None

void *ft_memccpy(void *dst, const void *src, int c, size_t n)

Description Param. #1 Param. #2 Param. #3 Param. #4 Return Value
Copies n bytes from memory area src to memory area dst, stopping when the character c is found, or after n characters are copied, whichever comes first. If copying takes place between objects that overlap, the behavior is undefined. Memory area dst Memory area src A character to search Number of bytes that memccpy() copied A pointer to the next character in dst after c, or NULL if c was not found in the first n bytes

void *ft_memchr(const void *s, int c, size_t n)

Description Param. #1 Param. #2 Param. #3 Return Value
Scans the initial n bytes of s for the first instance of c Memory area s A character to search The number of bytes A pointer to the matching byte or NULL if the character does not occur in the given memory area

void *ft_memcmp(void *dst, const void *src, size_t n)

Description Param. #1 Param. #2 Param. #3 Return Value
Compares byte string s1 against byte string s2 Memory area s1 Memory area s2 The number of bytes < 0 if s1 is less than s2, > 0 if s1 is graeter than s2, = 0 if s1 is equal to s2

void *ft_memcpy(void *dst, const void *src, size_t n)

Description Param. #1 Param. #2 Param. #3 Return Value
Copies n bytes from memory area src to memory of dst. The memory areas must not overlap. Use ft_memmove if the memory areas do overlap. Memory area dst Memory area src The number of bytes A pointer to the memory area dst

void *ft_memmove(void *dst, const void *src, size_t len)

Description Param. #1 Param. #2 Param. #3 Return Value
Copies len bytes from the memory of src to dst. Memories may overlap. First, the bytes in src are copied into a temporary array and then to dst. Memory area dst Memory ares arc The number of bytes A pointer to the memory area dst

void *ft_memset(void *s, int c, size_t len)

Description Param. #1 Param. #2 Param. #3 Return Value
Fill with "len" bytes of "c" the memory of "s" The string on which to operate Value c (converted to an unsigned char) The number of bytes A pointer to the memory area s

Functions from <stdio.h>:

int printf(const char *format, ...)

Description Param. #1 Return Value
Formats and prints the data to the standard output according to the format string format. The ... denotes a variable number of arguments to be formatted and printed. The format string The number of characters printed (excluding the null byte)

See: https://en.cppreference.com/w/c/io/fprintf

void putchar_fd(char c, int fd)

Description Param. #1 Param. #2 Return Value
Writes the character c to the file descriptor fd. The character to write The file descriptor None

void putendl_fd(char *s, int fd)

Description Param. #1 Param. #2 Return Value
Writes the string s to the file descriptor fd followed by a newline character. If s is NULL, nothing is written. The string to write The file descriptor None

void putnbr_fd(int n, int fd)

Description Param. #1 Param. #2 Return Value
Writes the integer n to the file descriptor fd. The integer to write The file descriptor None

void putstr_fd(char *s, int fd)

Description Param. #1 Param. #2 Return Value
Writes the string s to the file descriptor fd. If s is NULL, nothing is written. The string to write The file descriptor None

Bonus (linked-list):

ft_lstadd_back - add new element at end of list.

void ft_lstadd_back(t_list **lst, t_list *new);

Description Param. #1 Param. #2 Return Value
Adds the node ’new’ at the end of the list. lst: The address of a pointer to the first link of a list. new: The address of a pointer to the node to be added to the list. None

ft_lstadd_front - add new element at beginning of list.

void ft_lstadd_front(t_list **lst, t_list *new);

Description Param. #1 Param. #2 Return Value
Adds the node ’new’ at the beginning of the list. lst: The address of a pointer to the first link of a list. new: The address of a pointer to the node to be added to the list. None

ft_lstclear - delete sequence of elements of list from a starting point.

void ft_lstclear(t_list **lst, void (*del)(void *));

Description Param. #1 Param. #2 Return Value
Deletes and frees the given node and every successor of that node, using the function ’del’ and free(3). Finally, the pointer to the list must be set to NULL. lst: The address of a pointer to a node. del: The address of the function used to delete the content. None

ft_lstdelone - delete element from list.

void ft_lstdelone(t_list *lst, void (*del)(void *));

Description Param. #1 Param. #2 Return Value
Takes as a parameter a node and frees the memory of the node’s content using the function ’del’ given as a parameter and free the node. The memory of ’next’ must not be freed. lst: The node to free. del: The address of the function used to delete the content. None

ft_lstiter - apply function to content of all list's elements.

void ft_lstiter(t_list *lst, void (*f)(void *));

Description Param. #1 Param. #2 Return Value
Iterates the list ’lst’ and applies the function ’f’ on the content of each node. lst: The address of a pointer to a node. f: The address of the function used to iterate on the list. None

ft_lstlast - Returns the last node of the list.

t_list *ft_lstlast(t_list *lst);

Description Param. #1 Return Value
Returns the last node of the list. lst: The beginning of the list. Last node of the list

ft_lstmap - apply function to content of all list's elements into new list.

t_list *ft_lstmap(t_list *lst, void *(*f)(void *), void (*del)(void *));

Description Param. #1 Param. #2 Param. #3 Return Value
Iterates the list ’lst’ and applies the function ’f’ on the content of each node. Creates a new list resulting of the successive applications of the function ’f’. The ’del’ function is used to delete the content of a node if needed. lst: The address of a pointer to a node. f: The address of the function used to iterate on the list. del: The address of the function used to delete the content of a node if needed. The new list. NULL if the allocation fails

ft_lstnew - create new list.

t_list *ft_lstnew(void *content);

Description Param. #1 Return Value
Allocates (with malloc(3)) and returns a new node. The member variable ’content’ is initialized with the value of the parameter ’content’. The variable ’next’ is initialized to NULL. content: The content to create the node with. The new node

ft_lstpenultimate - Returns the penultimate node of the list

t_list *ft_lstpenultimate(t_list **lst)

Description Param. #1 Return Value
Returns the node before the last node of the list. If the list has fewer than two nodes, it returns NULL. The address of a pointer to the first node of the list. The penultimate node of the list or NULL if the list is too short.

ft_lstsize - Counts the number of nodes in a list.

int ft_lstsize(t_list *lst);

Description Param. #1 Return Value
Counts the number of nodes in a list. lst: The beginning of the list. The length of the list

Non-standard Functions (Custom or Additional Implementation):

ft_split - split string, with specified character as delimiter, into an array of strings.

char **ft_split(char const *s, char c)

Description Param. #1 Param. #2 Return Value
Allocates (with malloc) and returns an array of strings obtained by splitting s using the character 'c' as a delimiter. The array must be ended by a NULL pointer The string to be split The delimiter character The array of new strings result of the split. NULL if the allocation fails

char **ft_delete_split_arr(char **arr)

Description Param. #1 Return Value
Frees each string in the array arr and then frees the array itself. The function returns NULL. The array of strings to be freed Always returns NULL

char *ft_strjoin(char const *s1, char const *s2)

Description Param. #1 Param. #2 Return Value
Allocates (with malloc) and returns a new string, result of the concatenation of s1 and s2 The prefix string The suffix string The new string. NULL if the allocation fails

char *ft_strmapi(char const *s, char (*f)(unsigned int, char))

Description Param. #1 Param. #2 Return Value
Applies the function f to each character of the string passed as argument to create a new string (with malloc) resulting from successive applications of f The string on which to iterate The function to apply to each character The string created from the successive applications of f. Returns NULL if the allocation fails

char *ft_strjoin(char const *s1, char const *s2)

Description Param. #1 Param. #2 Return Value
Allocates (with malloc) and returns a copy of the string given as argument without the characters specified in the set argument at the beginning and the end of the string The string to be trimmed The reference set of character to trim The trimmed string. NULL if the allocation fails

char *ft_substr(char const *s, unsigned int start, size_t len)

Description Param. #1 Param. #2 Param. #3 Return Value
Allocates (with malloc) and returns a substring from the string given in argument. The substring begins at index 'start' and is of maximum size 'len' The string from which create the substring The start index of the substring in the string The maximum length of the substring The substring. NULL if the allocation fails

ft_striteri - Applies a function to each character in a string with its index

void ft_striteri(char *s, void (*f)(unsigned int, char*));

Description Param. #1 Param. #2 Return Value
Applies the function ’f’ to each character of the string ’s’, passing the index and the character as arguments. s: The string to iterate over. f: The function to apply to each character of the string. None

ft_strpbrk - Locates the first occurrence of any character in a set of characters

char *ft_strpbrk(const char *s, char *accept);

Description Param. #1 Param. #2 Return Value
Searches the string ’s’ for the first occurrence of any character from the string ’accept’. s: The string to search within. accept: The set of characters to search for. The pointer to the first occurrence of any character from ’accept’ or NULL if no match is found.

ft_substrpbrk - Locates the first occurrence of any character in a set of characters within a substring

char *ft_substrpbrk(char *s, size_t len, char *accept);

Description Param. #1 Param. #2 Param. #3 Return Value
Searches the substring of ’s’ up to length ’len’ for the first occurrence of any character from ’accept’. s: The string to search within. len: The length of the substring to consider. accept: The set of characters to search for. The pointer to the first occurrence of any character from ’accept’ within the substring or NULL if no match is found.

get_next_line - Reads a line from a file descriptor

char *get_next_line(int fd);

Description Param. #1 Return Value
Reads from the file descriptor ’fd’ and returns the next line of text. Each call to this function will return the subsequent line of the file. If the end of file is reached or if an error occurs, it returns NULL. The returned line includes the newline character if it is present in the file; otherwise, it returns the text up to the end of the file. fd: The file descriptor from which to read. The next line read from the file or NULL if the end of file is reached or an error occurs.

About

Your very first own library. (Version: 15)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published