diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..e68d4d8 --- /dev/null +++ b/Makefile @@ -0,0 +1,54 @@ +# **************************************************************************** # +# # +# ::: :::::::: # +# Makefile :+: :+: :+: # +# +:+ +:+ +:+ # +# By: gbrochar +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2015/11/27 19:26:17 by gbrochar #+# #+# # +# Updated: 2016/05/09 11:50:29 by gbrochar ### ########.fr # +# # +# **************************************************************************** # + +NAME = fdf + +SRC = srcs/main.c \ + srcs/fdf.c \ + srcs/mlx_draw_line.c \ + srcs/key_hook.c \ + srcs/fdf_parsing.c \ + srcs/get_map.c \ + get_next_line/get_next_line.c \ + libft/libft.a + +OBJ = main.o \ + fdf.o \ + mlx_draw_line.o \ + key_hook.o \ + fdf_parsing.o \ + get_map.o \ + get_next_line.o + +CC = gcc + +FLAGS = -Wall -Werror -Wextra + +all: $(NAME) + +$(NAME): + make -C get_next_line/libft + make -C libft + $(CC) $(FLAGS) -I./includes/ $(SRC) -o $(NAME) -lmlx -framework \ + AppKit -framework OpenGL + +clean: + make -C get_next_line/libft clean + make -C libft clean + rm -f $(OBJ) + +fclean: clean + make -C get_next_line/libft fclean + make -C libft fclean + rm -f $(NAME) + +re: fclean all diff --git a/README.md b/README.md index 22f57e0..cf17572 100644 --- a/README.md +++ b/README.md @@ -1,3 +1 @@ -# fdf - -fil de fer (wireframe) : an isometric wireframe engine using minilibx. Will not compile if minilibx isn't installed on your system and will not compile on linux systems. \ No newline at end of file +# fdf \ No newline at end of file diff --git a/auteur b/auteur new file mode 100644 index 0000000..b363db4 --- /dev/null +++ b/auteur @@ -0,0 +1 @@ +gbrochar diff --git a/get_next_line/get_next_line.c b/get_next_line/get_next_line.c new file mode 100644 index 0000000..7091328 --- /dev/null +++ b/get_next_line/get_next_line.c @@ -0,0 +1,64 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* get_next_line.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/03/07 08:05:43 by gbrochar #+# #+# */ +/* Updated: 2016/03/12 08:43:46 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "get_next_line.h" + +int gnl_manage_stock(char **stock, char **line) +{ + char *tmp; + + if ((tmp = ft_strchr(*stock, '\n'))) + { + *tmp = '\0'; + *line = ft_strdup(*stock); + free(*stock); + *stock = ft_strdup(tmp + 1); + return (1); + } + *line = ft_strdup(*stock); + free(*stock); + return (0); +} + +int gnl_manage_read(char **stock, char **line) +{ + char *tmp; + + if ((tmp = ft_strchr(*stock, '\n'))) + { + *tmp = '\0'; + *line = ft_strjoin(*line, *stock); + free(*stock); + *stock = ft_strdup(tmp + 1); + return (1); + } + *line = ft_strjoin(*line, *stock); + return (0); +} + +int get_next_line(int fd, char **line) +{ + static char *stock = NULL; + int ret; + + if (stock) + if (gnl_manage_stock(&stock, line)) + return (1); + stock = ft_strnew(BUFF_SIZE); + while ((ret = read(fd, stock, BUFF_SIZE)) > 0) + { + stock[ret] = '\0'; + if (gnl_manage_read(&stock, line)) + return (1); + } + return (ret); +} diff --git a/get_next_line/get_next_line.h b/get_next_line/get_next_line.h new file mode 100644 index 0000000..29f968e --- /dev/null +++ b/get_next_line/get_next_line.h @@ -0,0 +1,24 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* get_next_line.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/02/28 22:19:58 by gbrochar #+# #+# */ +/* Updated: 2016/03/12 08:48:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef GET_NEXT_LINE_H +# define GET_NEXT_LINE_H + +# include "libft/libft.h" + +# define BUFF_SIZE 16 + +int get_next_line(int const fd, char **line); +int gnl_get_overflow(char **data_overflow, char **line); +int gnl_check_read(char *buf, char **data_overflow, char **line); + +#endif diff --git a/get_next_line/libft/Makefile b/get_next_line/libft/Makefile new file mode 100644 index 0000000..bb88ed5 --- /dev/null +++ b/get_next_line/libft/Makefile @@ -0,0 +1,47 @@ +# **************************************************************************** # +# # +# ::: :::::::: # +# Makefile :+: :+: :+: # +# +:+ +:+ +:+ # +# By: gbrochar +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2015/11/27 19:26:17 by gbrochar #+# #+# # +# Updated: 2016/02/28 07:10:52 by gbrochar ### ########.fr # +# # +# **************************************************************************** # + +NAME = libft.a + +SRC = ft_atoi.c ft_bzero.c ft_isalnum.c ft_isalpha.c ft_isascii.c ft_isdigit.c \ +ft_isprint.c ft_isspace.c ft_itoa.c ft_lstadd.c ft_lstdel.c ft_lstdelone.c \ +ft_lstiter.c ft_lstmap.c ft_lstnew.c ft_memalloc.c ft_memccpy.c ft_memchr.c \ +ft_memcmp.c ft_memcpy.c ft_memdel.c ft_memmove.c ft_memset.c ft_power.c \ +ft_putchar.c ft_putchar_fd.c ft_putendl.c ft_putendl_fd.c ft_putnbr.c \ +ft_putnbr_fd.c ft_putstr.c ft_putstr_fd.c ft_sort_int.c ft_sqrt.c ft_strcat.c \ +ft_strchr.c ft_strclr.c ft_strcmp.c ft_strcpy.c ft_strdel.c ft_strdup.c \ +ft_strequ.c ft_striter.c ft_striteri.c ft_strjoin.c ft_strlcat.c ft_strlen.c \ +ft_strmap.c ft_strmapi.c ft_strncat.c ft_strncmp.c ft_strncpy.c ft_strnequ.c \ +ft_strnew.c ft_strnstr.c ft_strrchr.c ft_strsplit.c ft_strstr.c ft_strsub.c \ +ft_strtrim.c ft_swap.c ft_tolower.c ft_toupper.c ft_lstadd_preview.c \ +ft_get_last_node.c + +OBJ = $(SRC:.c=.o) + +CC = gcc + +FLAGS = -Wall -Werror -Wextra + +all: $(NAME) + +$(NAME): + $(CC) $(FLAGS) -c $(SRC) + ar rc $(NAME) $(OBJ) + ranlib $(NAME) + +clean: + rm -f $(OBJ) + +fclean: clean + rm -f $(NAME) + +re: fclean all diff --git a/get_next_line/libft/ft_atoi.c b/get_next_line/libft/ft_atoi.c new file mode 100644 index 0000000..cc03ea3 --- /dev/null +++ b/get_next_line/libft/ft_atoi.c @@ -0,0 +1,32 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_atoi.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 19:18:43 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 15:01:36 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_atoi(const char *str) +{ + long result; + long sign; + + result = 0; + while (ft_isspace(*str)) + str++; + sign = (*str == '-') ? -1 : 1; + if (*str == '-' || *str == '+') + str++; + while (*str >= '0' && *str <= '9') + { + result = (result * 10) + (*str - '0'); + str++; + } + return ((int)(result * sign)); +} diff --git a/get_next_line/libft/ft_bzero.c b/get_next_line/libft/ft_bzero.c new file mode 100644 index 0000000..e2131b2 --- /dev/null +++ b/get_next_line/libft/ft_bzero.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_bzero.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 11:39:18 by gbrochar #+# #+# */ +/* Updated: 2015/11/24 20:46:21 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_bzero(void *s, size_t n) +{ + char *byte; + + byte = s; + while (n-- > 0) + { + *byte = 0; + byte++; + } +} diff --git a/get_next_line/libft/ft_get_last_node.c b/get_next_line/libft/ft_get_last_node.c new file mode 100644 index 0000000..ef59d02 --- /dev/null +++ b/get_next_line/libft/ft_get_last_node.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_get_last_node.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/02/28 07:10:21 by gbrochar #+# #+# */ +/* Updated: 2016/02/28 07:12:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +t_list *ft_get_last_node(t_list **alst) +{ + t_list *tmp; + + tmp = *alst; + while (tmp->next) + tmp = tmp->next; + return (tmp); +} diff --git a/get_next_line/libft/ft_isalnum.c b/get_next_line/libft/ft_isalnum.c new file mode 100644 index 0000000..f21a2cc --- /dev/null +++ b/get_next_line/libft/ft_isalnum.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isalnum.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:51:03 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:22:14 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isalnum(int c) +{ + return (ft_isalpha(c) || ft_isdigit(c)); +} diff --git a/get_next_line/libft/ft_isalpha.c b/get_next_line/libft/ft_isalpha.c new file mode 100644 index 0000000..e4f61d6 --- /dev/null +++ b/get_next_line/libft/ft_isalpha.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isalpha.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:59:08 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:42:21 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isalpha(int c) +{ + return (((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z') ? 1 : 0)); +} diff --git a/get_next_line/libft/ft_isascii.c b/get_next_line/libft/ft_isascii.c new file mode 100644 index 0000000..c7daff9 --- /dev/null +++ b/get_next_line/libft/ft_isascii.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isascii.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:48:25 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:32:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isascii(int c) +{ + return ((c >= 0 && c <= 127) ? 1 : 0); +} diff --git a/get_next_line/libft/ft_isdigit.c b/get_next_line/libft/ft_isdigit.c new file mode 100644 index 0000000..e850324 --- /dev/null +++ b/get_next_line/libft/ft_isdigit.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isdigit.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:53:19 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 14:41:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isdigit(int c) +{ + return ((c >= '0' && c <= '9') ? 1 : 0); +} diff --git a/get_next_line/libft/ft_isprint.c b/get_next_line/libft/ft_isprint.c new file mode 100644 index 0000000..72badb5 --- /dev/null +++ b/get_next_line/libft/ft_isprint.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isprint.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:44:48 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:33:24 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isprint(int c) +{ + return ((c >= 32 && c <= 126) ? 1 : 0); +} diff --git a/get_next_line/libft/ft_isspace.c b/get_next_line/libft/ft_isspace.c new file mode 100644 index 0000000..89eb16a --- /dev/null +++ b/get_next_line/libft/ft_isspace.c @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isspace.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 14:37:03 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 14:39:18 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isspace(int c) +{ + if (c == '\t' || c == '\n' || c == '\f' || c == '\v' || c == '\r' + || c == ' ') + return (1); + return (0); +} diff --git a/get_next_line/libft/ft_itoa.c b/get_next_line/libft/ft_itoa.c new file mode 100644 index 0000000..8439491 --- /dev/null +++ b/get_next_line/libft/ft_itoa.c @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_itoa.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:56:59 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 16:22:09 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_itoa(int n) +{ + char *str; + size_t str_size; + int n_mem; + + n_mem = n; + str_size = (n < 0) ? 3 : 2; + while ((n > 9 || n < -9) && str_size++) + n /= 10; + str = (char *)malloc((str_size--) * sizeof(char)); + if (!str) + return (NULL); + str[str_size--] = '\0'; + while (n_mem > 9 || n_mem < -9) + { + str[str_size--] = (n_mem < 0) ? -(n_mem % 10) + '0' : n_mem % 10 + '0'; + n_mem = n_mem / 10; + } + str[0] = (n_mem < 0) ? '-' : (n_mem + '0'); + str[1] = (n_mem < 0) ? (-n_mem + '0') : str[1]; + return (str); +} diff --git a/get_next_line/libft/ft_lstadd.c b/get_next_line/libft/ft_lstadd.c new file mode 100644 index 0000000..104dee9 --- /dev/null +++ b/get_next_line/libft/ft_lstadd.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstadd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/01 14:24:17 by gbrochar #+# #+# */ +/* Updated: 2016/02/26 14:02:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstadd(t_list **alst, t_list *new) +{ + t_list *tmp; + + tmp = *alst; + while (tmp->next != NULL) + tmp = tmp->next; + tmp->next = new; +} diff --git a/get_next_line/libft/ft_lstadd_preview.c b/get_next_line/libft/ft_lstadd_preview.c new file mode 100644 index 0000000..6fd80c0 --- /dev/null +++ b/get_next_line/libft/ft_lstadd_preview.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstadd_preview.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/01 14:24:17 by gbrochar #+# #+# */ +/* Updated: 2016/02/26 14:01:33 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstadd_preview(t_list **alst, t_list *new) +{ + new->next = *alst; + *alst = new; +} diff --git a/get_next_line/libft/ft_lstdel.c b/get_next_line/libft/ft_lstdel.c new file mode 100644 index 0000000..9c02c08 --- /dev/null +++ b/get_next_line/libft/ft_lstdel.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstdel.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/30 21:34:50 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 15:10:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstdel(t_list **alst, void (*del)(void *, size_t)) +{ + t_list *tmp; + + while (*alst) + { + tmp = *alst; + ft_lstdelone(alst, del); + *alst = tmp->next; + } +} diff --git a/get_next_line/libft/ft_lstdelone.c b/get_next_line/libft/ft_lstdelone.c new file mode 100644 index 0000000..3448e9a --- /dev/null +++ b/get_next_line/libft/ft_lstdelone.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstdelone.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/30 21:27:05 by gbrochar #+# #+# */ +/* Updated: 2015/12/02 13:28:32 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstdelone(t_list **alst, void (*del)(void *, size_t)) +{ + del((*alst)->content, (*alst)->content_size); + ft_memdel((void **)alst); +} diff --git a/get_next_line/libft/ft_lstiter.c b/get_next_line/libft/ft_lstiter.c new file mode 100644 index 0000000..5cddff7 --- /dev/null +++ b/get_next_line/libft/ft_lstiter.c @@ -0,0 +1,29 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstiter.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/02 13:38:16 by gbrochar #+# #+# */ +/* Updated: 2015/12/04 16:41:19 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstiter(t_list *lst, void (*f)(t_list *elem)) +{ + t_list *start; + t_list *tmp; + + start = lst; + while (lst->next) + { + tmp = lst; + f(lst); + lst = tmp->next; + } + f(lst); + lst = start; +} diff --git a/get_next_line/libft/ft_lstmap.c b/get_next_line/libft/ft_lstmap.c new file mode 100644 index 0000000..8341e24 --- /dev/null +++ b/get_next_line/libft/ft_lstmap.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstmap.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/02 14:33:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/02 16:17:18 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +t_list *ft_lstmap(t_list *lst, t_list *(*f)(t_list *elem)) +{ + t_list *lst_begin; + t_list *lst_new; + + lst_begin = ft_lstnew((f(lst))->content, (f(lst))->content_size); + lst_new = lst_begin; + lst = lst->next; + while (lst->next) + { + lst_new->next = ft_lstnew((f(lst))->content, (f(lst))->content_size); + lst_new = lst_new->next; + lst = lst->next; + } + lst_new->next = ft_lstnew((f(lst))->content, (f(lst))->content_size); + return (lst_begin); +} diff --git a/get_next_line/libft/ft_lstnew.c b/get_next_line/libft/ft_lstnew.c new file mode 100644 index 0000000..9413638 --- /dev/null +++ b/get_next_line/libft/ft_lstnew.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstnew.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/30 21:21:09 by gbrochar #+# #+# */ +/* Updated: 2016/02/27 21:04:51 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +t_list *ft_lstnew(void const *content, size_t content_size) +{ + t_list *lst; + + lst = (t_list *)malloc(sizeof(t_list)); + if (!lst) + return (NULL); + if (!content) + { + lst->content = NULL; + lst->content_size = 0; + } + else + { + lst->content = ft_memalloc(content_size); + if (!lst->content) + { + free(lst); + return (NULL); + } + ft_memmove(lst->content, content, content_size); + lst->content_size = content_size; + } + lst->next = NULL; + return (lst); +} diff --git a/get_next_line/libft/ft_memalloc.c b/get_next_line/libft/ft_memalloc.c new file mode 100644 index 0000000..374edbf --- /dev/null +++ b/get_next_line/libft/ft_memalloc.c @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memalloc.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 18:11:36 by gbrochar #+# #+# */ +/* Updated: 2016/02/27 21:04:55 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memalloc(size_t size) +{ + unsigned char *ptr; + size_t i; + + i = 0; + ptr = (unsigned char *)malloc(size); + if (!ptr) + return (NULL); + while (i < size) + ptr[i++] = 0; + return (ptr); +} diff --git a/get_next_line/libft/ft_memccpy.c b/get_next_line/libft/ft_memccpy.c new file mode 100644 index 0000000..0c624ee --- /dev/null +++ b/get_next_line/libft/ft_memccpy.c @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memccpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 14:40:00 by gbrochar #+# #+# */ +/* Updated: 2015/12/08 14:37:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memccpy(void *dst, const void *src, int c, size_t n) +{ + size_t i; + unsigned char to_find; + unsigned char *dst_byte; + unsigned char *src_byte; + + to_find = (unsigned char)c; + i = 0; + dst_byte = (unsigned char *)dst; + src_byte = (unsigned char *)src; + while (i != n && src_byte[i] != to_find) + { + dst_byte[i] = src_byte[i]; + i++; + } + if (src_byte[i] == to_find) + { + dst_byte[i] = to_find; + return (&dst[i + 1]); + } + return (NULL); +} diff --git a/get_next_line/libft/ft_memchr.c b/get_next_line/libft/ft_memchr.c new file mode 100644 index 0000000..fc6a9d9 --- /dev/null +++ b/get_next_line/libft/ft_memchr.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memchr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 13:03:54 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 14:07:56 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memchr(const void *s, int c, size_t n) +{ + unsigned char to_find; + unsigned char *str; + size_t i; + + i = 0; + to_find = c; + str = (unsigned char *)s; + while (i < n) + { + if (str[i] == to_find) + return ((void *)&s[i]); + i++; + } + return (NULL); +} diff --git a/get_next_line/libft/ft_memcmp.c b/get_next_line/libft/ft_memcmp.c new file mode 100644 index 0000000..18aa48e --- /dev/null +++ b/get_next_line/libft/ft_memcmp.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memcmp.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:13:46 by gbrochar #+# #+# */ +/* Updated: 2015/11/30 14:46:05 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_memcmp(const void *s1, const void *s2, size_t n) +{ + unsigned char *s1_byte; + unsigned char *s2_byte; + size_t i; + + s1_byte = (unsigned char *)s1; + s2_byte = (unsigned char *)s2; + i = 0; + if (n <= 0) + return (0); + while (s1_byte[i] == s2_byte[i]) + { + if (i + 1 == n) + return (0); + i++; + } + return (s1_byte[i] - s2_byte[i]); +} diff --git a/get_next_line/libft/ft_memcpy.c b/get_next_line/libft/ft_memcpy.c new file mode 100644 index 0000000..8a42505 --- /dev/null +++ b/get_next_line/libft/ft_memcpy.c @@ -0,0 +1,30 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memcpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:42:55 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 14:43:02 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memcpy(void *dst, const void *src, size_t n) +{ + size_t i; + unsigned char *dst_byte; + const unsigned char *src_byte; + + i = 0; + dst_byte = dst; + src_byte = src; + while (i < n) + { + dst_byte[i] = src_byte[i]; + i++; + } + return (dst); +} diff --git a/get_next_line/libft/ft_memdel.c b/get_next_line/libft/ft_memdel.c new file mode 100644 index 0000000..cd84e74 --- /dev/null +++ b/get_next_line/libft/ft_memdel.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memdel.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 18:23:10 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 18:25:10 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_memdel(void **ap) +{ + free(*ap); + *ap = NULL; +} diff --git a/get_next_line/libft/ft_memmove.c b/get_next_line/libft/ft_memmove.c new file mode 100644 index 0000000..ce42e2a --- /dev/null +++ b/get_next_line/libft/ft_memmove.c @@ -0,0 +1,39 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memmove.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 12:36:04 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 13:03:31 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memmove(void *dst, const void *src, size_t len) +{ + unsigned char *dst_byte; + const unsigned char *src_byte; + size_t index; + + dst_byte = dst; + src_byte = src; + if (dst_byte > src_byte) + { + index = len; + while (index-- > 0) + dst_byte[index] = src_byte[index]; + } + else + { + index = 0; + while (index < len) + { + dst_byte[index] = src_byte[index]; + index++; + } + } + return (dst); +} diff --git a/get_next_line/libft/ft_memset.c b/get_next_line/libft/ft_memset.c new file mode 100644 index 0000000..8606775 --- /dev/null +++ b/get_next_line/libft/ft_memset.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memset.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/23 17:53:16 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 12:18:32 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memset(void *b, int c, size_t len) +{ + unsigned char *byte; + size_t i; + + byte = b; + i = 0; + while (i++ < len) + { + *byte = c; + byte++; + } + return (b); +} diff --git a/get_next_line/libft/ft_power.c b/get_next_line/libft/ft_power.c new file mode 100644 index 0000000..130d4a4 --- /dev/null +++ b/get_next_line/libft/ft_power.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_power.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/05 15:23:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:03:41 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_power(int nb, int pow) +{ + int ret; + + ret = 1; + if (pow < 0) + return (-1); + while (pow--) + ret *= nb; + return (ret); +} diff --git a/get_next_line/libft/ft_putchar.c b/get_next_line/libft/ft_putchar.c new file mode 100644 index 0000000..82125ba --- /dev/null +++ b/get_next_line/libft/ft_putchar.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putchar.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 12:01:00 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 16:47:24 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putchar(char c) +{ + write(1, &c, 1); +} diff --git a/get_next_line/libft/ft_putchar_fd.c b/get_next_line/libft/ft_putchar_fd.c new file mode 100644 index 0000000..4fc2ee7 --- /dev/null +++ b/get_next_line/libft/ft_putchar_fd.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putchar_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:01:19 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:02:06 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putchar_fd(char c, int fd) +{ + write(fd, &c, 1); +} diff --git a/get_next_line/libft/ft_putendl.c b/get_next_line/libft/ft_putendl.c new file mode 100644 index 0000000..52a3be5 --- /dev/null +++ b/get_next_line/libft/ft_putendl.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putendl.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:04:13 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:04:50 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putendl(char const *s) +{ + ft_putstr(s); + ft_putchar('\n'); +} diff --git a/get_next_line/libft/ft_putendl_fd.c b/get_next_line/libft/ft_putendl_fd.c new file mode 100644 index 0000000..de5409b --- /dev/null +++ b/get_next_line/libft/ft_putendl_fd.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putendl_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:04:58 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:05:51 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putendl_fd(char const *s, int fd) +{ + ft_putstr_fd(s, fd); + ft_putchar_fd('\n', fd); +} diff --git a/get_next_line/libft/ft_putnbr.c b/get_next_line/libft/ft_putnbr.c new file mode 100644 index 0000000..7e6ab30 --- /dev/null +++ b/get_next_line/libft/ft_putnbr.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putnbr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 08:58:30 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:49:28 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putnbr(int n) +{ + if (n == -2147483648) + ft_putstr("-2147483648"); + else if (n < 0) + { + ft_putchar('-'); + ft_putnbr(-n); + } + else if (n > 9) + { + ft_putnbr(n / 10); + ft_putchar(n % 10 + '0'); + } + else + ft_putchar(n + '0'); +} diff --git a/get_next_line/libft/ft_putnbr_fd.c b/get_next_line/libft/ft_putnbr_fd.c new file mode 100644 index 0000000..070cfd2 --- /dev/null +++ b/get_next_line/libft/ft_putnbr_fd.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putnbr_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:10:52 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:49:38 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putnbr_fd(int n, int fd) +{ + if (n == -2147483648) + ft_putstr_fd("-2147483648", fd); + else if (n < 0) + { + ft_putchar_fd('-', fd); + ft_putnbr_fd(-n, fd); + } + else if (n > 9) + { + ft_putnbr_fd(n / 10, fd); + ft_putchar_fd(n % 10 + '0', fd); + } + else + ft_putchar_fd(n + '0', fd); +} diff --git a/get_next_line/libft/ft_putstr.c b/get_next_line/libft/ft_putstr.c new file mode 100644 index 0000000..a21c751 --- /dev/null +++ b/get_next_line/libft/ft_putstr.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putstr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:23:12 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:06:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putstr(char const *s) +{ + while (*s) + write(1, s++, 1); +} diff --git a/get_next_line/libft/ft_putstr_fd.c b/get_next_line/libft/ft_putstr_fd.c new file mode 100644 index 0000000..a7d909a --- /dev/null +++ b/get_next_line/libft/ft_putstr_fd.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putstr_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:02:48 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:04:05 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putstr_fd(char const *s, int fd) +{ + while (*s) + write(fd, s++, 1); +} diff --git a/get_next_line/libft/ft_sort_int.c b/get_next_line/libft/ft_sort_int.c new file mode 100644 index 0000000..9ed36cd --- /dev/null +++ b/get_next_line/libft/ft_sort_int.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_sort_int.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/05 18:36:08 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:04:19 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_sort_int(int *tab, int size) +{ + int i; + int tmp; + + i = 0; + while ((i + 1) < size) + { + if (tab[i] > tab[i + 1]) + { + tmp = tab[i]; + tab[i] = tab[i + 1]; + tab[i + 1] = tmp; + i = 0; + } + else + i++; + } +} diff --git a/get_next_line/libft/ft_sqrt.c b/get_next_line/libft/ft_sqrt.c new file mode 100644 index 0000000..7d71faf --- /dev/null +++ b/get_next_line/libft/ft_sqrt.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_sqrt.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/07 08:28:11 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 08:50:43 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +long ft_sqrt(long n) +{ + long sqrt; + + sqrt = 0; + while ((sqrt * sqrt) != n && (sqrt * sqrt) < n) + sqrt++; + return (((sqrt * sqrt) == n) ? (sqrt) : (-1)); +} diff --git a/get_next_line/libft/ft_strcat.c b/get_next_line/libft/ft_strcat.c new file mode 100644 index 0000000..4888e5c --- /dev/null +++ b/get_next_line/libft/ft_strcat.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strcat.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 16:26:53 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:19:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strcat(char *s1, const char *s2) +{ + char *p_s1; + const char *p_s2; + + p_s2 = s2; + p_s1 = s1; + while (*p_s1) + p_s1++; + while ((*p_s1++ = *p_s2++)) + ; + *p_s1 = '\0'; + return (s1); +} diff --git a/get_next_line/libft/ft_strchr.c b/get_next_line/libft/ft_strchr.c new file mode 100644 index 0000000..2578492 --- /dev/null +++ b/get_next_line/libft/ft_strchr.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strchr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 09:50:37 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:53:19 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strchr(const char *s, int c) +{ + if (s == NULL) + return (0); + while (*s != (char)c) + if (!*s++) + return (0); + return ((char *)s); +} diff --git a/get_next_line/libft/ft_strclr.c b/get_next_line/libft/ft_strclr.c new file mode 100644 index 0000000..6f9dc0a --- /dev/null +++ b/get_next_line/libft/ft_strclr.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strclr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 20:22:52 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 21:09:55 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_strclr(char *s) +{ + while (*s) + *s++ = '\0'; +} diff --git a/get_next_line/libft/ft_strcmp.c b/get_next_line/libft/ft_strcmp.c new file mode 100644 index 0000000..1d70b10 --- /dev/null +++ b/get_next_line/libft/ft_strcmp.c @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strcmp.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 14:52:37 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:34:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strcmp(const char *s1, const char *s2) +{ + while (*s1 || *s2) + if (*s1++ != *s2++) + return ((unsigned char)*--s1 - (unsigned char)*--s2); + return (0); +} diff --git a/get_next_line/libft/ft_strcpy.c b/get_next_line/libft/ft_strcpy.c new file mode 100644 index 0000000..631774f --- /dev/null +++ b/get_next_line/libft/ft_strcpy.c @@ -0,0 +1,26 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strcpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 15:10:54 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:32:41 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strcpy(char *dst, const char *src) +{ + char *p_dest; + const char *p_src; + + p_src = src; + p_dest = dst; + while ((*p_dest++ = *p_src++)) + ; + *p_dest = '\0'; + return (dst); +} diff --git a/get_next_line/libft/ft_strdel.c b/get_next_line/libft/ft_strdel.c new file mode 100644 index 0000000..75872b1 --- /dev/null +++ b/get_next_line/libft/ft_strdel.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strdel.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 20:21:47 by gbrochar #+# #+# */ +/* Updated: 2015/12/08 15:21:50 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_strdel(char **as) +{ + ft_memdel((void **)as); +} diff --git a/get_next_line/libft/ft_strdup.c b/get_next_line/libft/ft_strdup.c new file mode 100644 index 0000000..c995e55 --- /dev/null +++ b/get_next_line/libft/ft_strdup.c @@ -0,0 +1,29 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strdup.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:47:23 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:42:42 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strdup(const char *s1) +{ + int i; + char *dest; + + i = 0; + dest = malloc(sizeof(dest) * ft_strlen(s1) + 1); + while (s1[i]) + { + dest[i] = s1[i]; + i++; + } + dest[i] = '\0'; + return (dest); +} diff --git a/get_next_line/libft/ft_strequ.c b/get_next_line/libft/ft_strequ.c new file mode 100644 index 0000000..0e229a6 --- /dev/null +++ b/get_next_line/libft/ft_strequ.c @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strequ.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 08:35:37 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 15:47:45 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strequ(char const *s1, char const *s2) +{ + int i; + + i = 0; + while (s1[i] == s2[i]) + { + if (s1[i] == '\0' && s2[i] == '\0') + return (1); + i++; + } + return (0); +} diff --git a/get_next_line/libft/ft_striter.c b/get_next_line/libft/ft_striter.c new file mode 100644 index 0000000..4748141 --- /dev/null +++ b/get_next_line/libft/ft_striter.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_striter.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 20:37:55 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:51:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_striter(char *s, void (*f)(char *)) +{ + int i; + + i = 0; + while (s[i]) + { + f(&s[i]); + i++; + } +} diff --git a/get_next_line/libft/ft_striteri.c b/get_next_line/libft/ft_striteri.c new file mode 100644 index 0000000..bb633d0 --- /dev/null +++ b/get_next_line/libft/ft_striteri.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_striteri.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 21:02:16 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:30:40 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_striteri(char *s, void (*f)(unsigned int, char *s)) +{ + unsigned int i; + + i = 0; + while (s[i]) + { + f(i, &s[i]); + i++; + } +} diff --git a/get_next_line/libft/ft_strjoin.c b/get_next_line/libft/ft_strjoin.c new file mode 100644 index 0000000..1a47104 --- /dev/null +++ b/get_next_line/libft/ft_strjoin.c @@ -0,0 +1,34 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strjoin.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:48:11 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:03:58 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strjoin(char const *s1, char const *s2) +{ + size_t i; + char *new; + + s1 = (s1 == NULL) ? "" : s1; + s2 = (s2 == NULL) ? "" : s2; + if (s1 && s2) + { + i = ft_strlen(s1) + ft_strlen(s2); + new = ft_strnew(i); + if (new) + { + new = ft_strcpy(new, s1); + new = ft_strcat(new, s2); + return (new); + } + } + return (NULL); +} diff --git a/get_next_line/libft/ft_strlcat.c b/get_next_line/libft/ft_strlcat.c new file mode 100644 index 0000000..9823fd5 --- /dev/null +++ b/get_next_line/libft/ft_strlcat.c @@ -0,0 +1,32 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strlcat.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/26 08:00:59 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 15:48:23 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +size_t ft_strlcat(char *dst, const char *src, size_t size) +{ + size_t dst_len; + size_t src_len; + size_t i_src; + size_t i_dst; + + dst_len = ft_strlen(dst); + src_len = ft_strlen(src); + i_src = 0; + i_dst = dst_len; + if (dst_len >= size) + return (size + src_len); + while (src[i_src] && (size-- - (dst_len + 1)) > 0) + dst[i_dst++] = src[i_src++]; + dst[i_dst] = '\0'; + return (dst_len + src_len); +} diff --git a/get_next_line/libft/ft_strlen.c b/get_next_line/libft/ft_strlen.c new file mode 100644 index 0000000..cfcff92 --- /dev/null +++ b/get_next_line/libft/ft_strlen.c @@ -0,0 +1,24 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strlen.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:43:32 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:08:11 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +size_t ft_strlen(const char *s) +{ + int i; + + i = 0; + if (s) + while (s[i]) + i++; + return (i); +} diff --git a/get_next_line/libft/ft_strmap.c b/get_next_line/libft/ft_strmap.c new file mode 100644 index 0000000..fac7843 --- /dev/null +++ b/get_next_line/libft/ft_strmap.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strmap.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 21:30:34 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 16:53:26 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strmap(char const *s, char (*f)(char)) +{ + char *str; + int i; + int len; + + len = ft_strlen(s); + i = 0; + str = (char *)malloc((len + 1) * sizeof(char)); + if (!str) + return (NULL); + while (i < len) + { + str[i] = f(s[i]); + i++; + } + str[len] = '\0'; + return (str); +} diff --git a/get_next_line/libft/ft_strmapi.c b/get_next_line/libft/ft_strmapi.c new file mode 100644 index 0000000..a83e346 --- /dev/null +++ b/get_next_line/libft/ft_strmapi.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strmapi.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 21:39:30 by gbrochar #+# #+# */ +/* Updated: 2015/12/02 16:22:05 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strmapi(char const *s, char (*f)(unsigned int, char)) +{ + char *str; + unsigned int i; + + i = 0; + str = (char *)malloc((ft_strlen(s) + 1) * sizeof(char)); + if (!str) + return (NULL); + while (s[i]) + { + str[i] = f(i, s[i]); + i++; + } + str[i] = '\0'; + return (str); +} diff --git a/get_next_line/libft/ft_strncat.c b/get_next_line/libft/ft_strncat.c new file mode 100644 index 0000000..9a4b9eb --- /dev/null +++ b/get_next_line/libft/ft_strncat.c @@ -0,0 +1,30 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strncat.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 19:29:04 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 12:33:35 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strncat(char *s1, const char *s2, size_t n) +{ + size_t i_dst; + size_t i_src; + + i_dst = ft_strlen(s1); + i_src = 0; + while (i_src < n && s2[i_src] != '\0') + { + s1[i_dst] = s2[i_src]; + i_dst++; + i_src++; + } + s1[i_dst] = '\0'; + return (s1); +} diff --git a/get_next_line/libft/ft_strncmp.c b/get_next_line/libft/ft_strncmp.c new file mode 100644 index 0000000..db3be20 --- /dev/null +++ b/get_next_line/libft/ft_strncmp.c @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strncmp.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 14:57:36 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:34:45 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strncmp(const char *s1, const char *s2, size_t n) +{ + while ((*s1 || *s2) && n--) + if (*s1++ != *s2++) + return ((unsigned char)*--s1 - (unsigned char)*--s2); + return (0); +} diff --git a/get_next_line/libft/ft_strncpy.c b/get_next_line/libft/ft_strncpy.c new file mode 100644 index 0000000..173165b --- /dev/null +++ b/get_next_line/libft/ft_strncpy.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strncpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 16:18:18 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 16:21:09 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strncpy(char *dst, const char *src, size_t n) +{ + size_t i; + + i = 0; + while (i != n && src[i] != '\0') + { + dst[i] = src[i]; + i++; + } + while (i != n) + { + dst[i] = '\0'; + i++; + } + return (dst); +} diff --git a/get_next_line/libft/ft_strnequ.c b/get_next_line/libft/ft_strnequ.c new file mode 100644 index 0000000..ece7ced --- /dev/null +++ b/get_next_line/libft/ft_strnequ.c @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strnequ.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 08:37:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 16:24:50 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strnequ(char const *s1, char const *s2, size_t n) +{ + size_t i; + + i = 0; + while (s1[i] == s2[i] || i == n) + { + if ((s1[i] == '\0' && s2[i] == '\0') || i == n) + return (1); + i++; + } + return (0); +} diff --git a/get_next_line/libft/ft_strnew.c b/get_next_line/libft/ft_strnew.c new file mode 100644 index 0000000..425202b --- /dev/null +++ b/get_next_line/libft/ft_strnew.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strnew.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 18:26:56 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:06:10 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strnew(size_t size) +{ + char *str; + + str = (char *)malloc(size * sizeof(char) + 1); + if (!str) + return (NULL); + return (str); +} diff --git a/get_next_line/libft/ft_strnstr.c b/get_next_line/libft/ft_strnstr.c new file mode 100644 index 0000000..1982911 --- /dev/null +++ b/get_next_line/libft/ft_strnstr.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strnstr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 12:49:32 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 16:39:13 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strnstr(const char *s1, char *s2, size_t n) +{ + size_t i; + size_t i_mem; + size_t i_tofind; + + i_mem = 0; + if (s2[0] == '\0') + return ((char *)s1); + while (s1[i_mem] != '\0' && i_mem < n) + { + i_tofind = 0; + while (s1[i_mem] != s2[i_tofind] && s1[i_mem] != '\0') + i_mem++; + if (s1[i_mem] == '\0') + return (NULL); + i = i_mem; + while ((s1[i] == s2[i_tofind] || s2[i_tofind] == '\0') && i++ <= n) + if (s2[i_tofind++] == '\0') + return ((char *)&s1[i_mem]); + if (i > n) + return (NULL); + i_mem++; + } + return (NULL); +} diff --git a/get_next_line/libft/ft_strrchr.c b/get_next_line/libft/ft_strrchr.c new file mode 100644 index 0000000..e295607 --- /dev/null +++ b/get_next_line/libft/ft_strrchr.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strrchr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 10:05:56 by gbrochar #+# #+# */ +/* Updated: 2015/11/27 10:24:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strrchr(const char *s, int c) +{ + int i; + + i = ft_strlen(s); + if (c) + { + while (i--) + if (s[i] == (char)c) + return ((char *)&s[i]); + return (NULL); + } + return ((char *)&s[i]); +} diff --git a/get_next_line/libft/ft_strsplit.c b/get_next_line/libft/ft_strsplit.c new file mode 100644 index 0000000..0784026 --- /dev/null +++ b/get_next_line/libft/ft_strsplit.c @@ -0,0 +1,87 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strsplit.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:55:10 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:00:21 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +static int ft_wordcount(char const *s, char c) +{ + int word_count; + int i; + + i = 0; + word_count = 0; + while (s[i] != '\0') + { + while (s[i] == c) + i++; + if (s[i] != '\0') + word_count++; + while (s[i] != c && s[i] != '\0') + i++; + } + return (word_count); +} + +static void *ft_taballoc(char const *s, char **str_tab, char c) +{ + int i; + int i2; + int wl; + + i = 0; + i2 = 0; + while (s[i2]) + { + wl = 0; + while (s[i2] == c && s[i2] != '\0') + i2++; + while (s[i2] != c && s[i2] != '\0') + { + wl++; + i2++; + } + if (wl != 0) + *str_tab++ = (char *)malloc((wl + 1) * sizeof(char)); + if (!(str_tab - 1)) + return (NULL); + } + return (*str_tab); +} + +char **ft_strsplit(char const *s, char c) +{ + char **str_tab; + int i; + int i2; + int i3; + int wc; + + i = 0; + i3 = 0; + wc = ft_wordcount(s, c); + str_tab = (char **)malloc((wc + 1) * sizeof(char *)); + if (!str_tab) + return (NULL); + ft_taballoc(s, str_tab, c); + while (i != wc) + { + i2 = 0; + while (s[i3] == c && s[i3] != '\0') + i3++; + while (s[i3] != c && s[i3] != '\0') + str_tab[i][i2++] = s[i3++]; + str_tab[i][i2] = '\0'; + i++; + } + str_tab[i] = NULL; + return (str_tab); +} diff --git a/get_next_line/libft/ft_strstr.c b/get_next_line/libft/ft_strstr.c new file mode 100644 index 0000000..5f985f0 --- /dev/null +++ b/get_next_line/libft/ft_strstr.c @@ -0,0 +1,38 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strstr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 10:24:53 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 16:38:40 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strstr(const char *s1, char *s2) +{ + int i; + int i_mem; + int i_tofind; + + i_mem = 0; + if (s2[0] == '\0') + return ((char *)s1); + while (s1[i_mem] != '\0') + { + i_tofind = 0; + while (s1[i_mem] != s2[i_tofind] && s1[i_mem] != '\0') + i_mem++; + if (s1[i_mem] == '\0') + return (NULL); + i = i_mem; + while (s1[i++] == s2[i_tofind] || s2[i_tofind] == '\0') + if (s2[i_tofind++] == '\0') + return ((char *)&s1[i_mem]); + i_mem++; + } + return (NULL); +} diff --git a/get_next_line/libft/ft_strsub.c b/get_next_line/libft/ft_strsub.c new file mode 100644 index 0000000..4434689 --- /dev/null +++ b/get_next_line/libft/ft_strsub.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strsub.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:14:36 by gbrochar #+# #+# */ +/* Updated: 2015/12/08 15:34:26 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strsub(char const *s, unsigned int start, size_t len) +{ + char *str; + size_t i; + + i = 0; + str = (char *)malloc((len + 1) * sizeof(char)); + if (!str) + return (NULL); + while (i < len) + str[i++] = s[start++]; + str[i] = '\0'; + return (str); +} diff --git a/get_next_line/libft/ft_strtrim.c b/get_next_line/libft/ft_strtrim.c new file mode 100644 index 0000000..c3480c6 --- /dev/null +++ b/get_next_line/libft/ft_strtrim.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strtrim.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:54:12 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:00:33 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strtrim(char const *s) +{ + char *str; + size_t i; + size_t i2; + size_t ws; + + i = ft_strlen(s) - 1; + i2 = 0; + ws = 0; + while ((s[i] == ' ' || s[i] == '\n' || s[i] == '\t') && i--) + ws++; + i = 0; + while ((s[i] == ' ' || s[i] == '\n' || s[i] == '\t') && ws < ft_strlen(s)) + { + i++; + ws++; + } + str = (char *)malloc((ft_strlen(s) + 1 - ws) * sizeof(char)); + if (!str) + return (NULL); + while (i2 < (ft_strlen(s) - ws)) + str[i2++] = s[i++]; + str[i2] = '\0'; + return (str); +} diff --git a/get_next_line/libft/ft_swap.c b/get_next_line/libft/ft_swap.c new file mode 100644 index 0000000..5a99a20 --- /dev/null +++ b/get_next_line/libft/ft_swap.c @@ -0,0 +1,22 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_swap.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/07 09:44:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:01:13 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_swap(int *a, int *b) +{ + int c; + + c = *a; + *a = *b; + *b = c; +} diff --git a/get_next_line/libft/ft_tolower.c b/get_next_line/libft/ft_tolower.c new file mode 100644 index 0000000..22b7a20 --- /dev/null +++ b/get_next_line/libft/ft_tolower.c @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_tolower.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:39:55 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 08:40:07 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_tolower(int c) +{ + if ((int)c >= 'A' && (int)c <= 'Z') + c += 32; + return (c); +} diff --git a/get_next_line/libft/ft_toupper.c b/get_next_line/libft/ft_toupper.c new file mode 100644 index 0000000..f0f24ec --- /dev/null +++ b/get_next_line/libft/ft_toupper.c @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_toupper.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:43:24 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 16:01:01 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_toupper(int c) +{ + if ((int)c >= 'a' && (int)c <= 'z') + c -= 32; + return (c); +} diff --git a/get_next_line/libft/libft.h b/get_next_line/libft/libft.h new file mode 100644 index 0000000..f0b9bdc --- /dev/null +++ b/get_next_line/libft/libft.h @@ -0,0 +1,93 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* libft.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 12:52:28 by gbrochar #+# #+# */ +/* Updated: 2016/02/28 07:12:16 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef LIBFT_H +# define LIBFT_H + +# include +# include +# include + +typedef struct s_list +{ + void *content; + size_t content_size; + struct s_list *next; +} t_list; + +t_list *ft_get_last_node(t_list **alst); +void ft_lstadd(t_list **alst, t_list *new); +void ft_lstadd_preview(t_list **alst, t_list *new); +void ft_lstdel(t_list **alst, void (*del)(void *, size_t)); +void ft_lstdelone(t_list **alst, void (*del)(void *, size_t)); +t_list *ft_lstnew(void const *content, size_t content_size); +void ft_lstiter(t_list *lst, void (*f)(t_list *elem)); +t_list *ft_lstmap(t_list *lst, t_list *(*f)(t_list *elem)); +int ft_atoi(const char *str); +void ft_bzero(void *s, size_t n); +int ft_isalnum(int c); +int ft_isalpha(int c); +int ft_isascii(int c); +int ft_isdigit(int c); +int ft_isprint(int c); +int ft_isspace(int c); +char *ft_itoa(int n); +void *ft_memalloc(size_t size); +void *ft_memccpy(void *dst, const void *src, int c, size_t n); +void *ft_memchr(const void *s, int c, size_t n); +int ft_memcmp(const void *s1, const void *s2, size_t n); +void *ft_memcpy(void *dst, const void *src, size_t n); +void ft_memdel(void **ap); +void *ft_memmove(void *dst, const void *src, size_t len); +void *ft_memset(void *b, int c, size_t len); +int ft_power(int nb, int pow); +void ft_putchar(char c); +void ft_putchar_fd(char c, int fd); +void ft_putendl(char const *s); +void ft_putendl_fd(char const *s, int fd); +void ft_putnbr(int n); +void ft_putnbr_fd(int n, int fd); +void ft_putstr(char const *s); +void ft_putstr_fd(char const *s, int fd); +void ft_sort_int(int *tab, int size); +long ft_sqrt(long n); +char *ft_strcat(char *s1, const char *s2); +char *ft_strchr(const char *s, int c); +void ft_strclr(char *s); +int ft_strcmp(const char *s1, const char *s2); +char *ft_strcpy(char *dst, const char *src); +void ft_strdel(char **as); +char *ft_strdup(const char *s1); +int ft_strequ(char const *s1, char const *s2); +void ft_striter(char *s, void (*f)(char *)); +void ft_striteri(char *s, void (*f)(unsigned int, char *s)); +char *ft_strjoin(char const *s1, char const *s2); +size_t ft_strlcat(char *dst, const char *src, size_t size); +size_t ft_strlen(const char *s); +char *ft_strmap(char const *s, char (*f)(char)); +char *ft_strmapi(char const *s, char (*f)(unsigned int, char)); +char *ft_strncat(char *s1, const char *s2, size_t n); +int ft_strncmp(const char *s1, const char *s2, size_t n); +char *ft_strncpy(char *dst, const char *src, size_t n); +int ft_strnequ(char const *s1, char const *s2, size_t n); +char *ft_strnew(size_t size); +char *ft_strnstr(const char *s1, char *s2, size_t n); +char *ft_strrchr(const char *s, int c); +char **ft_strsplit(char const *s, char c); +char *ft_strstr(const char *s1, char *s2); +char *ft_strsub(char const *s, unsigned int start, size_t len); +char *ft_strtrim(char const *s); +void ft_swap(int *a, int *b); +int ft_tolower(int c); +int ft_toupper(int c); + +#endif diff --git a/includes/fdf.h b/includes/fdf.h new file mode 100644 index 0000000..9f40ed5 --- /dev/null +++ b/includes/fdf.h @@ -0,0 +1,72 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* fdf.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/02/29 03:24:20 by gbrochar #+# #+# */ +/* Updated: 2016/05/09 11:45:28 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef FDF_H +# define FDF_H + +# include "mlx.h" +# include "../libft/libft.h" +# include "../get_next_line/get_next_line.h" +# include +# include + +# define ABS(a) ((a) < 0 ? -(a) : (a)) + +# define COLOR 0xFFFFFF +# define ZOOM 1 +# define DEPTH 1 +# define TILE_WIDTH 32 +# define TILE_HEIGHT 16 +# define ORIGINX 960 +# define ORIGINY 100 +# define WINX 1920 +# define WINY 1080 + +typedef struct s_fdf +{ + int x; + int y; + int color; + int nothing; +} t_fdf; + +typedef struct s_mlx +{ + void *ptr; + void *win; + int xmax; + int x0; + int x1; + int x2; + int zmax; + int y0; + int y1; + int y2; + float h; + float w; + int color; + int **grid; + float d; + float z; + int **m; +} t_mlx; + +int **get_struct(char ***fdf_map); +int **fdf_parsing(char *file_name, t_mlx *mlx); +void mlx_swap(t_mlx *mlx); +void reset(t_mlx *mlx); +void mlx_draw_line(t_mlx mlx); +int *ft_atoi_split(char **to_split, t_mlx *mlx); +void fdf(t_mlx mlx); +int key_hook(int keycode, void *mlx_void); + +#endif diff --git a/libft/Makefile b/libft/Makefile new file mode 100644 index 0000000..ec6ad00 --- /dev/null +++ b/libft/Makefile @@ -0,0 +1,47 @@ +# **************************************************************************** # +# # +# ::: :::::::: # +# Makefile :+: :+: :+: # +# +:+ +:+ +:+ # +# By: gbrochar +#+ +:+ +#+ # +# +#+#+#+#+#+ +#+ # +# Created: 2015/11/27 19:26:17 by gbrochar #+# #+# # +# Updated: 2016/05/09 11:32:25 by gbrochar ### ########.fr # +# # +# **************************************************************************** # + +NAME = libft.a + +SRC = ft_atoi.c ft_bzero.c ft_isalnum.c ft_isalpha.c ft_isascii.c ft_isdigit.c \ +ft_isprint.c ft_isspace.c ft_itoa.c ft_lstadd.c ft_lstdel.c ft_lstdelone.c \ +ft_lstiter.c ft_lstmap.c ft_lstnew.c ft_memalloc.c ft_memccpy.c ft_memchr.c \ +ft_memcmp.c ft_memcpy.c ft_memdel.c ft_memmove.c ft_memset.c ft_power.c \ +ft_putchar.c ft_putchar_fd.c ft_putendl.c ft_putendl_fd.c ft_putnbr.c \ +ft_putnbr_fd.c ft_putstr.c ft_putstr_fd.c ft_sort_int.c ft_sqrt.c ft_strcat.c \ +ft_strchr.c ft_strclr.c ft_strcmp.c ft_strcpy.c ft_strdel.c ft_strdup.c \ +ft_strequ.c ft_striter.c ft_striteri.c ft_strjoin.c ft_strlcat.c ft_strlen.c \ +ft_strmap.c ft_strmapi.c ft_strncat.c ft_strncmp.c ft_strncpy.c ft_strnequ.c \ +ft_strnew.c ft_strnstr.c ft_strrchr.c ft_strsplit.c ft_strstr.c ft_strsub.c \ +ft_strtrim.c ft_swap.c ft_tolower.c ft_toupper.c ft_lstadd_preview.c \ +ft_get_last_node.c ft_ishexdigit.c ft_atoi_len.c ft_atoi_color.c + +OBJ = $(SRC:.c=.o) + +CC = gcc + +FLAGS = -Wall -Werror -Wextra + +all: $(NAME) + +$(NAME): + $(CC) $(FLAGS) -c $(SRC) + ar rc $(NAME) $(OBJ) + ranlib $(NAME) + +clean: + rm -f $(OBJ) + +fclean: clean + rm -f $(NAME) + +re: fclean all diff --git a/libft/ft_atoi.c b/libft/ft_atoi.c new file mode 100644 index 0000000..cc03ea3 --- /dev/null +++ b/libft/ft_atoi.c @@ -0,0 +1,32 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_atoi.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 19:18:43 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 15:01:36 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_atoi(const char *str) +{ + long result; + long sign; + + result = 0; + while (ft_isspace(*str)) + str++; + sign = (*str == '-') ? -1 : 1; + if (*str == '-' || *str == '+') + str++; + while (*str >= '0' && *str <= '9') + { + result = (result * 10) + (*str - '0'); + str++; + } + return ((int)(result * sign)); +} diff --git a/libft/ft_atoi_color.c b/libft/ft_atoi_color.c new file mode 100644 index 0000000..598c3cb --- /dev/null +++ b/libft/ft_atoi_color.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_atoi_color.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 19:18:43 by gbrochar #+# #+# */ +/* Updated: 2016/05/06 10:25:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_atoi_color(char *hexa_color) +{ + int i; + int result; + + result = 0; + i = 5; + while (i >= 0) + { + if (hexa_color[i] >= '0' && hexa_color[i] <= '9') + result += (hexa_color[i] - '0') * ft_power(16, (6 - i)); + else if (hexa_color[i] >= 'A' && hexa_color[i] <= 'F') + result += (hexa_color[i] - '0') * ft_power(16, (6 - i)); + else + return (-1); + i--; + } + return (result); +} diff --git a/libft/ft_atoi_len.c b/libft/ft_atoi_len.c new file mode 100644 index 0000000..b52b7ce --- /dev/null +++ b/libft/ft_atoi_len.c @@ -0,0 +1,35 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_atoi_len.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 19:18:43 by gbrochar #+# #+# */ +/* Updated: 2016/05/06 11:45:55 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_atoi_len(char *str, int *len) +{ + int result; + int sign; + + result = 0; + *len = 0; + sign = (*str == '-') ? -1 : 1; + if (*str == '-' || *str == '+') + { + str++; + len++; + } + while (*str >= '0' && *str <= '9') + { + result = (result * 10) + (*str - '0'); + str++; + len++; + } + return (result * sign); +} diff --git a/libft/ft_bzero.c b/libft/ft_bzero.c new file mode 100644 index 0000000..e2131b2 --- /dev/null +++ b/libft/ft_bzero.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_bzero.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 11:39:18 by gbrochar #+# #+# */ +/* Updated: 2015/11/24 20:46:21 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_bzero(void *s, size_t n) +{ + char *byte; + + byte = s; + while (n-- > 0) + { + *byte = 0; + byte++; + } +} diff --git a/libft/ft_get_last_node.c b/libft/ft_get_last_node.c new file mode 100644 index 0000000..ef59d02 --- /dev/null +++ b/libft/ft_get_last_node.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_get_last_node.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/02/28 07:10:21 by gbrochar #+# #+# */ +/* Updated: 2016/02/28 07:12:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +t_list *ft_get_last_node(t_list **alst) +{ + t_list *tmp; + + tmp = *alst; + while (tmp->next) + tmp = tmp->next; + return (tmp); +} diff --git a/libft/ft_isalnum.c b/libft/ft_isalnum.c new file mode 100644 index 0000000..f21a2cc --- /dev/null +++ b/libft/ft_isalnum.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isalnum.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:51:03 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:22:14 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isalnum(int c) +{ + return (ft_isalpha(c) || ft_isdigit(c)); +} diff --git a/libft/ft_isalpha.c b/libft/ft_isalpha.c new file mode 100644 index 0000000..e4f61d6 --- /dev/null +++ b/libft/ft_isalpha.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isalpha.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:59:08 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:42:21 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isalpha(int c) +{ + return (((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z') ? 1 : 0)); +} diff --git a/libft/ft_isascii.c b/libft/ft_isascii.c new file mode 100644 index 0000000..c7daff9 --- /dev/null +++ b/libft/ft_isascii.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isascii.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:48:25 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:32:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isascii(int c) +{ + return ((c >= 0 && c <= 127) ? 1 : 0); +} diff --git a/libft/ft_isdigit.c b/libft/ft_isdigit.c new file mode 100644 index 0000000..e850324 --- /dev/null +++ b/libft/ft_isdigit.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isdigit.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:53:19 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 14:41:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isdigit(int c) +{ + return ((c >= '0' && c <= '9') ? 1 : 0); +} diff --git a/libft/ft_ishexdigit.c b/libft/ft_ishexdigit.c new file mode 100644 index 0000000..e4b4691 --- /dev/null +++ b/libft/ft_ishexdigit.c @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_ishexdigit.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/05/05 23:22:51 by gbrochar #+# #+# */ +/* Updated: 2016/05/05 23:24:26 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_ishexdigit(int c) +{ + if (ft_isdigit(c) || (c >= 'a' && c <= 'f') || (c >= 'A' && c <= 'F')) + return (1); + return (0); +} diff --git a/libft/ft_isprint.c b/libft/ft_isprint.c new file mode 100644 index 0000000..72badb5 --- /dev/null +++ b/libft/ft_isprint.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isprint.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:44:48 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:33:24 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isprint(int c) +{ + return ((c >= 32 && c <= 126) ? 1 : 0); +} diff --git a/libft/ft_isspace.c b/libft/ft_isspace.c new file mode 100644 index 0000000..89eb16a --- /dev/null +++ b/libft/ft_isspace.c @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_isspace.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 14:37:03 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 14:39:18 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_isspace(int c) +{ + if (c == '\t' || c == '\n' || c == '\f' || c == '\v' || c == '\r' + || c == ' ') + return (1); + return (0); +} diff --git a/libft/ft_itoa.c b/libft/ft_itoa.c new file mode 100644 index 0000000..8439491 --- /dev/null +++ b/libft/ft_itoa.c @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_itoa.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:56:59 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 16:22:09 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_itoa(int n) +{ + char *str; + size_t str_size; + int n_mem; + + n_mem = n; + str_size = (n < 0) ? 3 : 2; + while ((n > 9 || n < -9) && str_size++) + n /= 10; + str = (char *)malloc((str_size--) * sizeof(char)); + if (!str) + return (NULL); + str[str_size--] = '\0'; + while (n_mem > 9 || n_mem < -9) + { + str[str_size--] = (n_mem < 0) ? -(n_mem % 10) + '0' : n_mem % 10 + '0'; + n_mem = n_mem / 10; + } + str[0] = (n_mem < 0) ? '-' : (n_mem + '0'); + str[1] = (n_mem < 0) ? (-n_mem + '0') : str[1]; + return (str); +} diff --git a/libft/ft_lstadd.c b/libft/ft_lstadd.c new file mode 100644 index 0000000..104dee9 --- /dev/null +++ b/libft/ft_lstadd.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstadd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/01 14:24:17 by gbrochar #+# #+# */ +/* Updated: 2016/02/26 14:02:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstadd(t_list **alst, t_list *new) +{ + t_list *tmp; + + tmp = *alst; + while (tmp->next != NULL) + tmp = tmp->next; + tmp->next = new; +} diff --git a/libft/ft_lstadd_preview.c b/libft/ft_lstadd_preview.c new file mode 100644 index 0000000..6fd80c0 --- /dev/null +++ b/libft/ft_lstadd_preview.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstadd_preview.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/01 14:24:17 by gbrochar #+# #+# */ +/* Updated: 2016/02/26 14:01:33 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstadd_preview(t_list **alst, t_list *new) +{ + new->next = *alst; + *alst = new; +} diff --git a/libft/ft_lstdel.c b/libft/ft_lstdel.c new file mode 100644 index 0000000..9c02c08 --- /dev/null +++ b/libft/ft_lstdel.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstdel.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/30 21:34:50 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 15:10:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstdel(t_list **alst, void (*del)(void *, size_t)) +{ + t_list *tmp; + + while (*alst) + { + tmp = *alst; + ft_lstdelone(alst, del); + *alst = tmp->next; + } +} diff --git a/libft/ft_lstdelone.c b/libft/ft_lstdelone.c new file mode 100644 index 0000000..3448e9a --- /dev/null +++ b/libft/ft_lstdelone.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstdelone.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/30 21:27:05 by gbrochar #+# #+# */ +/* Updated: 2015/12/02 13:28:32 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstdelone(t_list **alst, void (*del)(void *, size_t)) +{ + del((*alst)->content, (*alst)->content_size); + ft_memdel((void **)alst); +} diff --git a/libft/ft_lstiter.c b/libft/ft_lstiter.c new file mode 100644 index 0000000..5cddff7 --- /dev/null +++ b/libft/ft_lstiter.c @@ -0,0 +1,29 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstiter.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/02 13:38:16 by gbrochar #+# #+# */ +/* Updated: 2015/12/04 16:41:19 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_lstiter(t_list *lst, void (*f)(t_list *elem)) +{ + t_list *start; + t_list *tmp; + + start = lst; + while (lst->next) + { + tmp = lst; + f(lst); + lst = tmp->next; + } + f(lst); + lst = start; +} diff --git a/libft/ft_lstmap.c b/libft/ft_lstmap.c new file mode 100644 index 0000000..8341e24 --- /dev/null +++ b/libft/ft_lstmap.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstmap.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/02 14:33:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/02 16:17:18 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +t_list *ft_lstmap(t_list *lst, t_list *(*f)(t_list *elem)) +{ + t_list *lst_begin; + t_list *lst_new; + + lst_begin = ft_lstnew((f(lst))->content, (f(lst))->content_size); + lst_new = lst_begin; + lst = lst->next; + while (lst->next) + { + lst_new->next = ft_lstnew((f(lst))->content, (f(lst))->content_size); + lst_new = lst_new->next; + lst = lst->next; + } + lst_new->next = ft_lstnew((f(lst))->content, (f(lst))->content_size); + return (lst_begin); +} diff --git a/libft/ft_lstnew.c b/libft/ft_lstnew.c new file mode 100644 index 0000000..9413638 --- /dev/null +++ b/libft/ft_lstnew.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_lstnew.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/30 21:21:09 by gbrochar #+# #+# */ +/* Updated: 2016/02/27 21:04:51 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +t_list *ft_lstnew(void const *content, size_t content_size) +{ + t_list *lst; + + lst = (t_list *)malloc(sizeof(t_list)); + if (!lst) + return (NULL); + if (!content) + { + lst->content = NULL; + lst->content_size = 0; + } + else + { + lst->content = ft_memalloc(content_size); + if (!lst->content) + { + free(lst); + return (NULL); + } + ft_memmove(lst->content, content, content_size); + lst->content_size = content_size; + } + lst->next = NULL; + return (lst); +} diff --git a/libft/ft_memalloc.c b/libft/ft_memalloc.c new file mode 100644 index 0000000..374edbf --- /dev/null +++ b/libft/ft_memalloc.c @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memalloc.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 18:11:36 by gbrochar #+# #+# */ +/* Updated: 2016/02/27 21:04:55 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memalloc(size_t size) +{ + unsigned char *ptr; + size_t i; + + i = 0; + ptr = (unsigned char *)malloc(size); + if (!ptr) + return (NULL); + while (i < size) + ptr[i++] = 0; + return (ptr); +} diff --git a/libft/ft_memccpy.c b/libft/ft_memccpy.c new file mode 100644 index 0000000..0c624ee --- /dev/null +++ b/libft/ft_memccpy.c @@ -0,0 +1,37 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memccpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 14:40:00 by gbrochar #+# #+# */ +/* Updated: 2015/12/08 14:37:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memccpy(void *dst, const void *src, int c, size_t n) +{ + size_t i; + unsigned char to_find; + unsigned char *dst_byte; + unsigned char *src_byte; + + to_find = (unsigned char)c; + i = 0; + dst_byte = (unsigned char *)dst; + src_byte = (unsigned char *)src; + while (i != n && src_byte[i] != to_find) + { + dst_byte[i] = src_byte[i]; + i++; + } + if (src_byte[i] == to_find) + { + dst_byte[i] = to_find; + return (&dst[i + 1]); + } + return (NULL); +} diff --git a/libft/ft_memchr.c b/libft/ft_memchr.c new file mode 100644 index 0000000..fc6a9d9 --- /dev/null +++ b/libft/ft_memchr.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memchr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 13:03:54 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 14:07:56 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memchr(const void *s, int c, size_t n) +{ + unsigned char to_find; + unsigned char *str; + size_t i; + + i = 0; + to_find = c; + str = (unsigned char *)s; + while (i < n) + { + if (str[i] == to_find) + return ((void *)&s[i]); + i++; + } + return (NULL); +} diff --git a/libft/ft_memcmp.c b/libft/ft_memcmp.c new file mode 100644 index 0000000..18aa48e --- /dev/null +++ b/libft/ft_memcmp.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memcmp.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:13:46 by gbrochar #+# #+# */ +/* Updated: 2015/11/30 14:46:05 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_memcmp(const void *s1, const void *s2, size_t n) +{ + unsigned char *s1_byte; + unsigned char *s2_byte; + size_t i; + + s1_byte = (unsigned char *)s1; + s2_byte = (unsigned char *)s2; + i = 0; + if (n <= 0) + return (0); + while (s1_byte[i] == s2_byte[i]) + { + if (i + 1 == n) + return (0); + i++; + } + return (s1_byte[i] - s2_byte[i]); +} diff --git a/libft/ft_memcpy.c b/libft/ft_memcpy.c new file mode 100644 index 0000000..8a42505 --- /dev/null +++ b/libft/ft_memcpy.c @@ -0,0 +1,30 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memcpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:42:55 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 14:43:02 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memcpy(void *dst, const void *src, size_t n) +{ + size_t i; + unsigned char *dst_byte; + const unsigned char *src_byte; + + i = 0; + dst_byte = dst; + src_byte = src; + while (i < n) + { + dst_byte[i] = src_byte[i]; + i++; + } + return (dst); +} diff --git a/libft/ft_memdel.c b/libft/ft_memdel.c new file mode 100644 index 0000000..cd84e74 --- /dev/null +++ b/libft/ft_memdel.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memdel.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 18:23:10 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 18:25:10 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_memdel(void **ap) +{ + free(*ap); + *ap = NULL; +} diff --git a/libft/ft_memmove.c b/libft/ft_memmove.c new file mode 100644 index 0000000..ce42e2a --- /dev/null +++ b/libft/ft_memmove.c @@ -0,0 +1,39 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memmove.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 12:36:04 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 13:03:31 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memmove(void *dst, const void *src, size_t len) +{ + unsigned char *dst_byte; + const unsigned char *src_byte; + size_t index; + + dst_byte = dst; + src_byte = src; + if (dst_byte > src_byte) + { + index = len; + while (index-- > 0) + dst_byte[index] = src_byte[index]; + } + else + { + index = 0; + while (index < len) + { + dst_byte[index] = src_byte[index]; + index++; + } + } + return (dst); +} diff --git a/libft/ft_memset.c b/libft/ft_memset.c new file mode 100644 index 0000000..8606775 --- /dev/null +++ b/libft/ft_memset.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_memset.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/23 17:53:16 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 12:18:32 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void *ft_memset(void *b, int c, size_t len) +{ + unsigned char *byte; + size_t i; + + byte = b; + i = 0; + while (i++ < len) + { + *byte = c; + byte++; + } + return (b); +} diff --git a/libft/ft_power.c b/libft/ft_power.c new file mode 100644 index 0000000..130d4a4 --- /dev/null +++ b/libft/ft_power.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_power.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/05 15:23:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:03:41 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_power(int nb, int pow) +{ + int ret; + + ret = 1; + if (pow < 0) + return (-1); + while (pow--) + ret *= nb; + return (ret); +} diff --git a/libft/ft_putchar.c b/libft/ft_putchar.c new file mode 100644 index 0000000..82125ba --- /dev/null +++ b/libft/ft_putchar.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putchar.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 12:01:00 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 16:47:24 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putchar(char c) +{ + write(1, &c, 1); +} diff --git a/libft/ft_putchar_fd.c b/libft/ft_putchar_fd.c new file mode 100644 index 0000000..4fc2ee7 --- /dev/null +++ b/libft/ft_putchar_fd.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putchar_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:01:19 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:02:06 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putchar_fd(char c, int fd) +{ + write(fd, &c, 1); +} diff --git a/libft/ft_putendl.c b/libft/ft_putendl.c new file mode 100644 index 0000000..52a3be5 --- /dev/null +++ b/libft/ft_putendl.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putendl.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:04:13 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:04:50 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putendl(char const *s) +{ + ft_putstr(s); + ft_putchar('\n'); +} diff --git a/libft/ft_putendl_fd.c b/libft/ft_putendl_fd.c new file mode 100644 index 0000000..de5409b --- /dev/null +++ b/libft/ft_putendl_fd.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putendl_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:04:58 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:05:51 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putendl_fd(char const *s, int fd) +{ + ft_putstr_fd(s, fd); + ft_putchar_fd('\n', fd); +} diff --git a/libft/ft_putnbr.c b/libft/ft_putnbr.c new file mode 100644 index 0000000..7e6ab30 --- /dev/null +++ b/libft/ft_putnbr.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putnbr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 08:58:30 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:49:28 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putnbr(int n) +{ + if (n == -2147483648) + ft_putstr("-2147483648"); + else if (n < 0) + { + ft_putchar('-'); + ft_putnbr(-n); + } + else if (n > 9) + { + ft_putnbr(n / 10); + ft_putchar(n % 10 + '0'); + } + else + ft_putchar(n + '0'); +} diff --git a/libft/ft_putnbr_fd.c b/libft/ft_putnbr_fd.c new file mode 100644 index 0000000..070cfd2 --- /dev/null +++ b/libft/ft_putnbr_fd.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putnbr_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:10:52 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:49:38 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putnbr_fd(int n, int fd) +{ + if (n == -2147483648) + ft_putstr_fd("-2147483648", fd); + else if (n < 0) + { + ft_putchar_fd('-', fd); + ft_putnbr_fd(-n, fd); + } + else if (n > 9) + { + ft_putnbr_fd(n / 10, fd); + ft_putchar_fd(n % 10 + '0', fd); + } + else + ft_putchar_fd(n + '0', fd); +} diff --git a/libft/ft_putstr.c b/libft/ft_putstr.c new file mode 100644 index 0000000..a21c751 --- /dev/null +++ b/libft/ft_putstr.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putstr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:23:12 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:06:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putstr(char const *s) +{ + while (*s) + write(1, s++, 1); +} diff --git a/libft/ft_putstr_fd.c b/libft/ft_putstr_fd.c new file mode 100644 index 0000000..a7d909a --- /dev/null +++ b/libft/ft_putstr_fd.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_putstr_fd.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:02:48 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 09:04:05 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_putstr_fd(char const *s, int fd) +{ + while (*s) + write(fd, s++, 1); +} diff --git a/libft/ft_sort_int.c b/libft/ft_sort_int.c new file mode 100644 index 0000000..9ed36cd --- /dev/null +++ b/libft/ft_sort_int.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_sort_int.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/05 18:36:08 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:04:19 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_sort_int(int *tab, int size) +{ + int i; + int tmp; + + i = 0; + while ((i + 1) < size) + { + if (tab[i] > tab[i + 1]) + { + tmp = tab[i]; + tab[i] = tab[i + 1]; + tab[i + 1] = tmp; + i = 0; + } + else + i++; + } +} diff --git a/libft/ft_sqrt.c b/libft/ft_sqrt.c new file mode 100644 index 0000000..7d71faf --- /dev/null +++ b/libft/ft_sqrt.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_sqrt.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/07 08:28:11 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 08:50:43 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +long ft_sqrt(long n) +{ + long sqrt; + + sqrt = 0; + while ((sqrt * sqrt) != n && (sqrt * sqrt) < n) + sqrt++; + return (((sqrt * sqrt) == n) ? (sqrt) : (-1)); +} diff --git a/libft/ft_strcat.c b/libft/ft_strcat.c new file mode 100644 index 0000000..4888e5c --- /dev/null +++ b/libft/ft_strcat.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strcat.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 16:26:53 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:19:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strcat(char *s1, const char *s2) +{ + char *p_s1; + const char *p_s2; + + p_s2 = s2; + p_s1 = s1; + while (*p_s1) + p_s1++; + while ((*p_s1++ = *p_s2++)) + ; + *p_s1 = '\0'; + return (s1); +} diff --git a/libft/ft_strchr.c b/libft/ft_strchr.c new file mode 100644 index 0000000..2578492 --- /dev/null +++ b/libft/ft_strchr.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strchr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 09:50:37 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:53:19 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strchr(const char *s, int c) +{ + if (s == NULL) + return (0); + while (*s != (char)c) + if (!*s++) + return (0); + return ((char *)s); +} diff --git a/libft/ft_strclr.c b/libft/ft_strclr.c new file mode 100644 index 0000000..6f9dc0a --- /dev/null +++ b/libft/ft_strclr.c @@ -0,0 +1,19 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strclr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 20:22:52 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 21:09:55 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_strclr(char *s) +{ + while (*s) + *s++ = '\0'; +} diff --git a/libft/ft_strcmp.c b/libft/ft_strcmp.c new file mode 100644 index 0000000..1d70b10 --- /dev/null +++ b/libft/ft_strcmp.c @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strcmp.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 14:52:37 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:34:12 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strcmp(const char *s1, const char *s2) +{ + while (*s1 || *s2) + if (*s1++ != *s2++) + return ((unsigned char)*--s1 - (unsigned char)*--s2); + return (0); +} diff --git a/libft/ft_strcpy.c b/libft/ft_strcpy.c new file mode 100644 index 0000000..631774f --- /dev/null +++ b/libft/ft_strcpy.c @@ -0,0 +1,26 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strcpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 15:10:54 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:32:41 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strcpy(char *dst, const char *src) +{ + char *p_dest; + const char *p_src; + + p_src = src; + p_dest = dst; + while ((*p_dest++ = *p_src++)) + ; + *p_dest = '\0'; + return (dst); +} diff --git a/libft/ft_strdel.c b/libft/ft_strdel.c new file mode 100644 index 0000000..75872b1 --- /dev/null +++ b/libft/ft_strdel.c @@ -0,0 +1,18 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strdel.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 20:21:47 by gbrochar #+# #+# */ +/* Updated: 2015/12/08 15:21:50 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_strdel(char **as) +{ + ft_memdel((void **)as); +} diff --git a/libft/ft_strdup.c b/libft/ft_strdup.c new file mode 100644 index 0000000..c995e55 --- /dev/null +++ b/libft/ft_strdup.c @@ -0,0 +1,29 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strdup.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:47:23 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:42:42 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strdup(const char *s1) +{ + int i; + char *dest; + + i = 0; + dest = malloc(sizeof(dest) * ft_strlen(s1) + 1); + while (s1[i]) + { + dest[i] = s1[i]; + i++; + } + dest[i] = '\0'; + return (dest); +} diff --git a/libft/ft_strequ.c b/libft/ft_strequ.c new file mode 100644 index 0000000..0e229a6 --- /dev/null +++ b/libft/ft_strequ.c @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strequ.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 08:35:37 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 15:47:45 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strequ(char const *s1, char const *s2) +{ + int i; + + i = 0; + while (s1[i] == s2[i]) + { + if (s1[i] == '\0' && s2[i] == '\0') + return (1); + i++; + } + return (0); +} diff --git a/libft/ft_striter.c b/libft/ft_striter.c new file mode 100644 index 0000000..4748141 --- /dev/null +++ b/libft/ft_striter.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_striter.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 20:37:55 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:51:54 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_striter(char *s, void (*f)(char *)) +{ + int i; + + i = 0; + while (s[i]) + { + f(&s[i]); + i++; + } +} diff --git a/libft/ft_striteri.c b/libft/ft_striteri.c new file mode 100644 index 0000000..bb633d0 --- /dev/null +++ b/libft/ft_striteri.c @@ -0,0 +1,25 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_striteri.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 21:02:16 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 10:30:40 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_striteri(char *s, void (*f)(unsigned int, char *s)) +{ + unsigned int i; + + i = 0; + while (s[i]) + { + f(i, &s[i]); + i++; + } +} diff --git a/libft/ft_strjoin.c b/libft/ft_strjoin.c new file mode 100644 index 0000000..1a47104 --- /dev/null +++ b/libft/ft_strjoin.c @@ -0,0 +1,34 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strjoin.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:48:11 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:03:58 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strjoin(char const *s1, char const *s2) +{ + size_t i; + char *new; + + s1 = (s1 == NULL) ? "" : s1; + s2 = (s2 == NULL) ? "" : s2; + if (s1 && s2) + { + i = ft_strlen(s1) + ft_strlen(s2); + new = ft_strnew(i); + if (new) + { + new = ft_strcpy(new, s1); + new = ft_strcat(new, s2); + return (new); + } + } + return (NULL); +} diff --git a/libft/ft_strlcat.c b/libft/ft_strlcat.c new file mode 100644 index 0000000..9823fd5 --- /dev/null +++ b/libft/ft_strlcat.c @@ -0,0 +1,32 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strlcat.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/26 08:00:59 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 15:48:23 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +size_t ft_strlcat(char *dst, const char *src, size_t size) +{ + size_t dst_len; + size_t src_len; + size_t i_src; + size_t i_dst; + + dst_len = ft_strlen(dst); + src_len = ft_strlen(src); + i_src = 0; + i_dst = dst_len; + if (dst_len >= size) + return (size + src_len); + while (src[i_src] && (size-- - (dst_len + 1)) > 0) + dst[i_dst++] = src[i_src++]; + dst[i_dst] = '\0'; + return (dst_len + src_len); +} diff --git a/libft/ft_strlen.c b/libft/ft_strlen.c new file mode 100644 index 0000000..cfcff92 --- /dev/null +++ b/libft/ft_strlen.c @@ -0,0 +1,24 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strlen.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 14:43:32 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:08:11 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +size_t ft_strlen(const char *s) +{ + int i; + + i = 0; + if (s) + while (s[i]) + i++; + return (i); +} diff --git a/libft/ft_strmap.c b/libft/ft_strmap.c new file mode 100644 index 0000000..fac7843 --- /dev/null +++ b/libft/ft_strmap.c @@ -0,0 +1,33 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strmap.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 21:30:34 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 16:53:26 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strmap(char const *s, char (*f)(char)) +{ + char *str; + int i; + int len; + + len = ft_strlen(s); + i = 0; + str = (char *)malloc((len + 1) * sizeof(char)); + if (!str) + return (NULL); + while (i < len) + { + str[i] = f(s[i]); + i++; + } + str[len] = '\0'; + return (str); +} diff --git a/libft/ft_strmapi.c b/libft/ft_strmapi.c new file mode 100644 index 0000000..a83e346 --- /dev/null +++ b/libft/ft_strmapi.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strmapi.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 21:39:30 by gbrochar #+# #+# */ +/* Updated: 2015/12/02 16:22:05 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strmapi(char const *s, char (*f)(unsigned int, char)) +{ + char *str; + unsigned int i; + + i = 0; + str = (char *)malloc((ft_strlen(s) + 1) * sizeof(char)); + if (!str) + return (NULL); + while (s[i]) + { + str[i] = f(i, s[i]); + i++; + } + str[i] = '\0'; + return (str); +} diff --git a/libft/ft_strncat.c b/libft/ft_strncat.c new file mode 100644 index 0000000..9a4b9eb --- /dev/null +++ b/libft/ft_strncat.c @@ -0,0 +1,30 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strncat.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 19:29:04 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 12:33:35 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strncat(char *s1, const char *s2, size_t n) +{ + size_t i_dst; + size_t i_src; + + i_dst = ft_strlen(s1); + i_src = 0; + while (i_src < n && s2[i_src] != '\0') + { + s1[i_dst] = s2[i_src]; + i_dst++; + i_src++; + } + s1[i_dst] = '\0'; + return (s1); +} diff --git a/libft/ft_strncmp.c b/libft/ft_strncmp.c new file mode 100644 index 0000000..db3be20 --- /dev/null +++ b/libft/ft_strncmp.c @@ -0,0 +1,21 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strncmp.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 14:57:36 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 15:34:45 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strncmp(const char *s1, const char *s2, size_t n) +{ + while ((*s1 || *s2) && n--) + if (*s1++ != *s2++) + return ((unsigned char)*--s1 - (unsigned char)*--s2); + return (0); +} diff --git a/libft/ft_strncpy.c b/libft/ft_strncpy.c new file mode 100644 index 0000000..173165b --- /dev/null +++ b/libft/ft_strncpy.c @@ -0,0 +1,31 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strncpy.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/25 16:18:18 by gbrochar #+# #+# */ +/* Updated: 2015/11/25 16:21:09 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strncpy(char *dst, const char *src, size_t n) +{ + size_t i; + + i = 0; + while (i != n && src[i] != '\0') + { + dst[i] = src[i]; + i++; + } + while (i != n) + { + dst[i] = '\0'; + i++; + } + return (dst); +} diff --git a/libft/ft_strnequ.c b/libft/ft_strnequ.c new file mode 100644 index 0000000..ece7ced --- /dev/null +++ b/libft/ft_strnequ.c @@ -0,0 +1,27 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strnequ.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 08:37:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/05 16:24:50 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_strnequ(char const *s1, char const *s2, size_t n) +{ + size_t i; + + i = 0; + while (s1[i] == s2[i] || i == n) + { + if ((s1[i] == '\0' && s2[i] == '\0') || i == n) + return (1); + i++; + } + return (0); +} diff --git a/libft/ft_strnew.c b/libft/ft_strnew.c new file mode 100644 index 0000000..425202b --- /dev/null +++ b/libft/ft_strnew.c @@ -0,0 +1,23 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strnew.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/28 18:26:56 by gbrochar #+# #+# */ +/* Updated: 2016/02/29 22:06:10 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strnew(size_t size) +{ + char *str; + + str = (char *)malloc(size * sizeof(char) + 1); + if (!str) + return (NULL); + return (str); +} diff --git a/libft/ft_strnstr.c b/libft/ft_strnstr.c new file mode 100644 index 0000000..1982911 --- /dev/null +++ b/libft/ft_strnstr.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strnstr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 12:49:32 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 16:39:13 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strnstr(const char *s1, char *s2, size_t n) +{ + size_t i; + size_t i_mem; + size_t i_tofind; + + i_mem = 0; + if (s2[0] == '\0') + return ((char *)s1); + while (s1[i_mem] != '\0' && i_mem < n) + { + i_tofind = 0; + while (s1[i_mem] != s2[i_tofind] && s1[i_mem] != '\0') + i_mem++; + if (s1[i_mem] == '\0') + return (NULL); + i = i_mem; + while ((s1[i] == s2[i_tofind] || s2[i_tofind] == '\0') && i++ <= n) + if (s2[i_tofind++] == '\0') + return ((char *)&s1[i_mem]); + if (i > n) + return (NULL); + i_mem++; + } + return (NULL); +} diff --git a/libft/ft_strrchr.c b/libft/ft_strrchr.c new file mode 100644 index 0000000..e295607 --- /dev/null +++ b/libft/ft_strrchr.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strrchr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 10:05:56 by gbrochar #+# #+# */ +/* Updated: 2015/11/27 10:24:37 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strrchr(const char *s, int c) +{ + int i; + + i = ft_strlen(s); + if (c) + { + while (i--) + if (s[i] == (char)c) + return ((char *)&s[i]); + return (NULL); + } + return ((char *)&s[i]); +} diff --git a/libft/ft_strsplit.c b/libft/ft_strsplit.c new file mode 100644 index 0000000..0784026 --- /dev/null +++ b/libft/ft_strsplit.c @@ -0,0 +1,87 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strsplit.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:55:10 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:00:21 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +static int ft_wordcount(char const *s, char c) +{ + int word_count; + int i; + + i = 0; + word_count = 0; + while (s[i] != '\0') + { + while (s[i] == c) + i++; + if (s[i] != '\0') + word_count++; + while (s[i] != c && s[i] != '\0') + i++; + } + return (word_count); +} + +static void *ft_taballoc(char const *s, char **str_tab, char c) +{ + int i; + int i2; + int wl; + + i = 0; + i2 = 0; + while (s[i2]) + { + wl = 0; + while (s[i2] == c && s[i2] != '\0') + i2++; + while (s[i2] != c && s[i2] != '\0') + { + wl++; + i2++; + } + if (wl != 0) + *str_tab++ = (char *)malloc((wl + 1) * sizeof(char)); + if (!(str_tab - 1)) + return (NULL); + } + return (*str_tab); +} + +char **ft_strsplit(char const *s, char c) +{ + char **str_tab; + int i; + int i2; + int i3; + int wc; + + i = 0; + i3 = 0; + wc = ft_wordcount(s, c); + str_tab = (char **)malloc((wc + 1) * sizeof(char *)); + if (!str_tab) + return (NULL); + ft_taballoc(s, str_tab, c); + while (i != wc) + { + i2 = 0; + while (s[i3] == c && s[i3] != '\0') + i3++; + while (s[i3] != c && s[i3] != '\0') + str_tab[i][i2++] = s[i3++]; + str_tab[i][i2] = '\0'; + i++; + } + str_tab[i] = NULL; + return (str_tab); +} diff --git a/libft/ft_strstr.c b/libft/ft_strstr.c new file mode 100644 index 0000000..5f985f0 --- /dev/null +++ b/libft/ft_strstr.c @@ -0,0 +1,38 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strstr.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 10:24:53 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 16:38:40 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strstr(const char *s1, char *s2) +{ + int i; + int i_mem; + int i_tofind; + + i_mem = 0; + if (s2[0] == '\0') + return ((char *)s1); + while (s1[i_mem] != '\0') + { + i_tofind = 0; + while (s1[i_mem] != s2[i_tofind] && s1[i_mem] != '\0') + i_mem++; + if (s1[i_mem] == '\0') + return (NULL); + i = i_mem; + while (s1[i++] == s2[i_tofind] || s2[i_tofind] == '\0') + if (s2[i_tofind++] == '\0') + return ((char *)&s1[i_mem]); + i_mem++; + } + return (NULL); +} diff --git a/libft/ft_strsub.c b/libft/ft_strsub.c new file mode 100644 index 0000000..4434689 --- /dev/null +++ b/libft/ft_strsub.c @@ -0,0 +1,28 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strsub.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:14:36 by gbrochar #+# #+# */ +/* Updated: 2015/12/08 15:34:26 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strsub(char const *s, unsigned int start, size_t len) +{ + char *str; + size_t i; + + i = 0; + str = (char *)malloc((len + 1) * sizeof(char)); + if (!str) + return (NULL); + while (i < len) + str[i++] = s[start++]; + str[i] = '\0'; + return (str); +} diff --git a/libft/ft_strtrim.c b/libft/ft_strtrim.c new file mode 100644 index 0000000..c3480c6 --- /dev/null +++ b/libft/ft_strtrim.c @@ -0,0 +1,40 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_strtrim.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/29 09:54:12 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:00:33 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +char *ft_strtrim(char const *s) +{ + char *str; + size_t i; + size_t i2; + size_t ws; + + i = ft_strlen(s) - 1; + i2 = 0; + ws = 0; + while ((s[i] == ' ' || s[i] == '\n' || s[i] == '\t') && i--) + ws++; + i = 0; + while ((s[i] == ' ' || s[i] == '\n' || s[i] == '\t') && ws < ft_strlen(s)) + { + i++; + ws++; + } + str = (char *)malloc((ft_strlen(s) + 1 - ws) * sizeof(char)); + if (!str) + return (NULL); + while (i2 < (ft_strlen(s) - ws)) + str[i2++] = s[i++]; + str[i2] = '\0'; + return (str); +} diff --git a/libft/ft_swap.c b/libft/ft_swap.c new file mode 100644 index 0000000..5a99a20 --- /dev/null +++ b/libft/ft_swap.c @@ -0,0 +1,22 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_swap.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/12/07 09:44:07 by gbrochar #+# #+# */ +/* Updated: 2015/12/07 11:01:13 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +void ft_swap(int *a, int *b) +{ + int c; + + c = *a; + *a = *b; + *b = c; +} diff --git a/libft/ft_tolower.c b/libft/ft_tolower.c new file mode 100644 index 0000000..22b7a20 --- /dev/null +++ b/libft/ft_tolower.c @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_tolower.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:39:55 by gbrochar #+# #+# */ +/* Updated: 2015/11/29 08:40:07 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_tolower(int c) +{ + if ((int)c >= 'A' && (int)c <= 'Z') + c += 32; + return (c); +} diff --git a/libft/ft_toupper.c b/libft/ft_toupper.c new file mode 100644 index 0000000..f0f24ec --- /dev/null +++ b/libft/ft_toupper.c @@ -0,0 +1,20 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* ft_toupper.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/27 18:43:24 by gbrochar #+# #+# */ +/* Updated: 2015/11/28 16:01:01 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "libft.h" + +int ft_toupper(int c) +{ + if ((int)c >= 'a' && (int)c <= 'z') + c -= 32; + return (c); +} diff --git a/libft/libft.h b/libft/libft.h new file mode 100644 index 0000000..76b0c99 --- /dev/null +++ b/libft/libft.h @@ -0,0 +1,96 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* libft.h :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2015/11/24 12:52:28 by gbrochar #+# #+# */ +/* Updated: 2016/05/06 11:16:31 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#ifndef LIBFT_H +# define LIBFT_H + +# include +# include +# include + +typedef struct s_list +{ + void *content; + size_t content_size; + struct s_list *next; +} t_list; + +t_list *ft_get_last_node(t_list **alst); +void ft_lstadd(t_list **alst, t_list *new); +void ft_lstadd_preview(t_list **alst, t_list *new); +void ft_lstdel(t_list **alst, void (*del)(void *, size_t)); +void ft_lstdelone(t_list **alst, void (*del)(void *, size_t)); +t_list *ft_lstnew(void const *content, size_t content_size); +void ft_lstiter(t_list *lst, void (*f)(t_list *elem)); +t_list *ft_lstmap(t_list *lst, t_list *(*f)(t_list *elem)); +int ft_atoi(const char *str); +int ft_atoi_color(char *hexa_color); +int ft_atoi_len(char *str, int *len); +void ft_bzero(void *s, size_t n); +int ft_isalnum(int c); +int ft_isalpha(int c); +int ft_isascii(int c); +int ft_isdigit(int c); +int ft_isprint(int c); +int ft_isspace(int c); +char *ft_itoa(int n); +void *ft_memalloc(size_t size); +void *ft_memccpy(void *dst, const void *src, int c, size_t n); +void *ft_memchr(const void *s, int c, size_t n); +int ft_memcmp(const void *s1, const void *s2, size_t n); +void *ft_memcpy(void *dst, const void *src, size_t n); +void ft_memdel(void **ap); +void *ft_memmove(void *dst, const void *src, size_t len); +void *ft_memset(void *b, int c, size_t len); +int ft_power(int nb, int pow); +void ft_putchar(char c); +void ft_putchar_fd(char c, int fd); +void ft_putendl(char const *s); +void ft_putendl_fd(char const *s, int fd); +void ft_putnbr(int n); +void ft_putnbr_fd(int n, int fd); +void ft_putstr(char const *s); +void ft_putstr_fd(char const *s, int fd); +void ft_sort_int(int *tab, int size); +long ft_sqrt(long n); +char *ft_strcat(char *s1, const char *s2); +char *ft_strchr(const char *s, int c); +void ft_strclr(char *s); +int ft_strcmp(const char *s1, const char *s2); +char *ft_strcpy(char *dst, const char *src); +void ft_strdel(char **as); +char *ft_strdup(const char *s1); +int ft_strequ(char const *s1, char const *s2); +void ft_striter(char *s, void (*f)(char *)); +void ft_striteri(char *s, void (*f)(unsigned int, char *s)); +char *ft_strjoin(char const *s1, char const *s2); +size_t ft_strlcat(char *dst, const char *src, size_t size); +size_t ft_strlen(const char *s); +char *ft_strmap(char const *s, char (*f)(char)); +char *ft_strmapi(char const *s, char (*f)(unsigned int, char)); +char *ft_strncat(char *s1, const char *s2, size_t n); +int ft_strncmp(const char *s1, const char *s2, size_t n); +char *ft_strncpy(char *dst, const char *src, size_t n); +int ft_strnequ(char const *s1, char const *s2, size_t n); +char *ft_strnew(size_t size); +char *ft_strnstr(const char *s1, char *s2, size_t n); +char *ft_strrchr(const char *s, int c); +char **ft_strsplit(char const *s, char c); +char *ft_strstr(const char *s1, char *s2); +char *ft_strsub(char const *s, unsigned int start, size_t len); +char *ft_strtrim(char const *s); +void ft_swap(int *a, int *b); +int ft_tolower(int c); +int ft_toupper(int c); +int ft_ishexdigit(int c); + +#endif diff --git a/srcs/fdf.c b/srcs/fdf.c new file mode 100644 index 0000000..4d95b7e --- /dev/null +++ b/srcs/fdf.c @@ -0,0 +1,42 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* fdf.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/03/14 20:49:19 by gbrochar #+# #+# */ +/* Updated: 2016/05/09 11:29:53 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "fdf.h" + +void fdf(t_mlx e) +{ + int i; + int j; + + i = -1; + while (++i != e.zmax) + { + j = -1; + while (++j != e.xmax) + { + e.x1 = e.x0 + ((j - i) * e.w); + e.y1 = e.y0 + ((j + i) * e.h) - e.m[i][j] * e.z * e.d; + if (j != e.xmax - 1) + { + e.x2 = e.x0 + (((j + 1) - i) * e.w); + e.y2 = e.y0 + (((j + 1) + i) * e.h) - e.m[i][j + 1] * e.z * e.d; + mlx_draw_line(e); + } + if (i != e.zmax - 1) + { + e.x2 = e.x0 + ((j - (i + 1)) * e.w); + e.y2 = e.y0 + ((j + (i + 1)) * e.h) - e.m[i + 1][j] * e.z * e.d; + mlx_draw_line(e); + } + } + } +} diff --git a/srcs/fdf_parsing.c b/srcs/fdf_parsing.c new file mode 100644 index 0000000..e289152 --- /dev/null +++ b/srcs/fdf_parsing.c @@ -0,0 +1,123 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* fdf_parsing.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/05/08 03:54:03 by gbrochar #+# #+# */ +/* Updated: 2016/05/09 11:23:53 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "fdf.h" + +char **get_file(int fd, char *file_name) +{ + char **file_content; + char *buffer; + int line_number; + int ret; + + line_number = 0; + while ((ret = get_next_line(fd, &buffer)) > 0) + line_number++; + if (ret == -1) + return (NULL); + file_content = (char **)malloc((line_number + 1) * sizeof(char *)); + file_content[line_number] = NULL; + close(fd); + if ((fd = open(file_name, O_RDONLY)) == -1) + return (NULL); + line_number = 0; + while ((ret = get_next_line(fd, &buffer)) > 0) + file_content[line_number++] = ft_strdup(buffer); + close(fd); + return (file_content); +} + +int check_str(char *str) +{ + int i; + int hex_count; + + i = 0; + hex_count = 0; + if (str[i] == '-') + ++i; + while (ft_isdigit(str[i]) == 1 && str[i]) + ++i; + if (str[i] == '\0') + return (0); + else + return (1); +} + +int **parse(char ***fdf_map) +{ + int i; + int j; + + i = 0; + while (fdf_map[i]) + { + j = 0; + while (fdf_map[i][j]) + { + if (check_str(fdf_map[i][j]) == 1) + return (NULL); + j++; + } + ++i; + } + return (get_struct(fdf_map)); +} + +int check_line_lenght(char ***fdf_map, t_mlx *mlx) +{ + int i; + int len; + int len_buf; + + i = 0; + len = 0; + while (fdf_map[i][len]) + ++len; + while (fdf_map[++i]) + { + len_buf = 0; + while (fdf_map[i][len_buf]) + ++len_buf; + if (len_buf != len) + return (1); + } + mlx->xmax = len; + return (0); +} + +int **fdf_parsing(char *file_name, t_mlx *mlx) +{ + char **file_content; + char ***fdf_map; + int fd; + int i; + + if ((fd = open(file_name, O_RDONLY)) == -1) + return (NULL); + file_content = get_file(fd, file_name); + i = 0; + while (file_content[i]) + i++; + fdf_map = (char ***)malloc((i + 1) * sizeof(char **)); + mlx->zmax = i; + fdf_map[i] = NULL; + i = 0; + while (file_content[i]) + { + fdf_map[i] = ft_strsplit(file_content[i], ' '); + ++i; + } + if (check_line_lenght(fdf_map, mlx)) + return (NULL); + return (parse(fdf_map)); +} diff --git a/srcs/get_map.c b/srcs/get_map.c new file mode 100644 index 0000000..67e062d --- /dev/null +++ b/srcs/get_map.c @@ -0,0 +1,63 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* get_map.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/05/05 23:44:15 by gbrochar #+# #+# */ +/* Updated: 2016/05/09 11:24:17 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "fdf.h" + +int **fdf_malloc_map(char ***fdf_map) +{ + int **map; + int i; + int i2; + int len; + + i = 0; + i2 = -1; + len = 0; + while (fdf_map[i]) + ++i; + while (fdf_map[0][len]) + len++; + if (!(map = (int **)malloc(i * sizeof(int *)))) + return (NULL); + while (++i2 != i) + if (!(map[i2] = (int *)malloc(len * sizeof(int)))) + return (NULL); + return (map); +} + +void get_map(int **map, char ***fdf_map) +{ + int i; + int j; + + i = 0; + while (fdf_map[i]) + { + j = 0; + while (fdf_map[i][j]) + { + map[i][j] = ft_atoi(fdf_map[i][j]); + ++j; + } + ++i; + } +} + +int **get_struct(char ***fdf_map) +{ + int **map; + + if (!(map = fdf_malloc_map(fdf_map))) + return (NULL); + get_map(map, fdf_map); + return (map); +} diff --git a/srcs/key_hook.c b/srcs/key_hook.c new file mode 100644 index 0000000..243befe --- /dev/null +++ b/srcs/key_hook.c @@ -0,0 +1,67 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* key_hook.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/03/15 11:23:56 by gbrochar #+# #+# */ +/* Updated: 2016/05/09 11:24:38 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "fdf.h" + +void manage_keycode_1(int keycode, t_mlx *mlx) +{ + if (keycode == 53) + exit(0); + if (keycode == 125 || keycode == 1) + mlx->y0 += 10; + if (keycode == 123 || keycode == 0) + mlx->x0 -= 10; + if (keycode == 124 || keycode == 2) + mlx->x0 += 10; + if (keycode == 126 || keycode == 13) + mlx->y0 -= 10; + if (keycode == 32) + mlx->d += 0.1; + if (keycode == 38 && mlx->d > 0) + mlx->d -= 0.1; + if (keycode == 16) + mlx->d += 0.5; + if (keycode == 4 && mlx->d > 1) + mlx->d -= 0.5; +} + +void manage_keycode_2(int keycode, t_mlx *mlx) +{ + if (keycode == 69) + { + mlx->z += 0.08; + mlx->y0 -= mlx->zmax; + mlx->w *= 1.2; + mlx->h *= 1.2; + } + if (keycode == 78 && mlx->h > 3) + { + mlx->z -= 0.08; + mlx->y0 += mlx->zmax; + mlx->w /= 1.2; + mlx->h /= 1.2; + } + if (keycode == 15) + reset(mlx); +} + +int key_hook(int keycode, void *mlx_void) +{ + t_mlx *mlx; + + mlx = (t_mlx *)mlx_void; + manage_keycode_1(keycode, mlx); + manage_keycode_2(keycode, mlx); + mlx_clear_window(mlx->ptr, mlx->win); + fdf(*mlx); + return (0); +} diff --git a/srcs/main.c b/srcs/main.c new file mode 100644 index 0000000..f5b529f --- /dev/null +++ b/srcs/main.c @@ -0,0 +1,62 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* main.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/02/29 03:22:54 by gbrochar #+# #+# */ +/* Updated: 2016/05/09 11:19:43 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "fdf.h" + +void reset(t_mlx *mlx) +{ + mlx->color = COLOR; + mlx->z = ZOOM; + mlx->d = DEPTH; + mlx->w = TILE_WIDTH; + mlx->h = TILE_HEIGHT; + mlx->x0 = ORIGINX; + mlx->y0 = ORIGINY; +} + +int init_mlx(t_mlx *mlx) +{ + if (!(mlx->ptr = mlx_init())) + return (1); + if (!(mlx->win = mlx_new_window(mlx->ptr, WINX, WINY, "42"))) + { + free(mlx->ptr); + return (1); + } + mlx_hook(mlx->win, 2, 1L << 1, &key_hook, mlx); + return (0); +} + +void ft_error(void) +{ + ft_putendl("error"); + exit(0); +} + +int main(int argc, char **argv) +{ + t_mlx mlx; + + if (argc == 2) + { + reset(&mlx); + if (!(mlx.m = fdf_parsing(argv[1], &mlx))) + ft_error(); + if (init_mlx(&mlx)) + ft_error(); + fdf(mlx); + mlx_loop(mlx.ptr); + } + else + ft_putendl("usage: ./fdf source_file"); + return (0); +} diff --git a/srcs/mlx_draw_line.c b/srcs/mlx_draw_line.c new file mode 100644 index 0000000..17000f4 --- /dev/null +++ b/srcs/mlx_draw_line.c @@ -0,0 +1,46 @@ +/* ************************************************************************** */ +/* */ +/* ::: :::::::: */ +/* mlx_draw_line.c :+: :+: :+: */ +/* +:+ +:+ +:+ */ +/* By: gbrochar +#+ +:+ +#+ */ +/* +#+#+#+#+#+ +#+ */ +/* Created: 2016/05/04 16:05:13 by gbrochar #+# #+# */ +/* Updated: 2016/05/05 23:49:25 by gbrochar ### ########.fr */ +/* */ +/* ************************************************************************** */ + +#include "fdf.h" + +void init_tool(int tool[6], t_mlx mlx) +{ + tool[0] = ABS(mlx.x2 - mlx.x1); + tool[1] = mlx.x1 < mlx.x2 ? 1 : -1; + tool[2] = -ABS(mlx.y2 - mlx.y1); + tool[3] = mlx.y1 < mlx.y2 ? 1 : -1; + tool[4] = tool[0] + tool[2]; +} + +void mlx_draw_line(t_mlx mlx) +{ + int tool[6]; + + init_tool(tool, mlx); + while (1) + { + mlx_pixel_put(mlx.ptr, mlx.win, mlx.x1, mlx.y1, mlx.color); + if (mlx.x1 == mlx.x2 && mlx.y1 == mlx.y2) + break ; + tool[5] = 2 * tool[4]; + if (tool[5] >= tool[2]) + { + tool[4] += tool[2]; + mlx.x1 += tool[1]; + } + if (tool[5] <= tool[0]) + { + tool[4] += tool[0]; + mlx.y1 += tool[3]; + } + } +}