add get_next_line
This commit is contained in:
		
							parent
							
								
									aaf7d13a7b
								
							
						
					
					
						commit
						f6de1aa948
					
				
					 6 changed files with 242 additions and 140 deletions
				
			
		|  | @ -11,7 +11,8 @@ | ||||||
| 
 | 
 | ||||||
| #include "libft.h" | #include "libft.h" | ||||||
| #include "mlx.h" | #include "mlx.h" | ||||||
| #include <stdio.h> // warning!! | #include <math.h> | ||||||
|  | #include <fcntl.h> | ||||||
| 
 | 
 | ||||||
| typedef struct	s_point | typedef struct	s_point | ||||||
| { | { | ||||||
|  | @ -33,6 +34,6 @@ typedef struct	s_swap | ||||||
| 	int 		swap_coord; | 	int 		swap_coord; | ||||||
| }				t_swap; | }				t_swap; | ||||||
| 
 | 
 | ||||||
| void	line(t_point p1, t_point p2, t_mlx m); | void	line(t_point *p1, t_point *p2, t_mlx *m); | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | @ -78,7 +78,8 @@ SRC = ft_memset.c		\ | ||||||
| 	  ft_lstadd_back.c	\
 | 	  ft_lstadd_back.c	\
 | ||||||
| 						\
 | 						\
 | ||||||
| 	  ft_realloc.c		\
 | 	  ft_realloc.c		\
 | ||||||
| 	  ft_read_file.c | 	  ft_read_file.c    \
 | ||||||
|  | 	  get_next_line.c | ||||||
| 
 | 
 | ||||||
| OBJ = $(SRC:.c=.o) | OBJ = $(SRC:.c=.o) | ||||||
| INC = -I ./includes/ | INC = -I ./includes/ | ||||||
|  |  | ||||||
|  | @ -16,11 +16,11 @@ char	*read_file(const int fd) | ||||||
| { | { | ||||||
| 	long	readed; | 	long	readed; | ||||||
| 	long	old_size; | 	long	old_size; | ||||||
| 	char	buf[BUF_S + 1]; | 	char	buf[BUFF_SIZE + 1]; | ||||||
| 	char	*string; | 	char	*string; | ||||||
| 
 | 
 | ||||||
| 	string = ft_memalloc(sizeof(char) * BUF_S); | 	string = ft_memalloc(sizeof(char) * BUFF_SIZE); | ||||||
| 	while ((readed = read(fd, buf, BUF_S))) | 	while ((readed = read(fd, buf, BUFF_SIZE))) | ||||||
| 	{ | 	{ | ||||||
| 		buf[readed] = '\0'; | 		buf[readed] = '\0'; | ||||||
| 		old_size = ft_strlen(string); | 		old_size = ft_strlen(string); | ||||||
|  |  | ||||||
							
								
								
									
										76
									
								
								libft/get_next_line.c
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								libft/get_next_line.c
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,76 @@ | ||||||
|  | /* ************************************************************************** */ | ||||||
|  | /*                                                                            */ | ||||||
|  | /*                                                        :::      ::::::::   */ | ||||||
|  | /*   get_next_line.c                                    :+:      :+:    :+:   */ | ||||||
|  | /*                                                    +:+ +:+         +:+     */ | ||||||
|  | /*   By: gtertysh <marvin@42.fr>                    +#+  +:+       +#+        */ | ||||||
|  | /*                                                +#+#+#+#+#+   +#+           */ | ||||||
|  | /*   Created: 2016/12/04 15:59:21 by gtertysh          #+#    #+#             */ | ||||||
|  | /*   Updated: 2016/12/06 19:45:44 by gtertysh         ###   ########.fr       */ | ||||||
|  | /*                                                                            */ | ||||||
|  | /* ************************************************************************** */ | ||||||
|  | 
 | ||||||
|  | #include "libft.h" | ||||||
|  | 
 | ||||||
|  | static t_fd    *new_node(int fd) | ||||||
|  | { | ||||||
|  |     t_fd	*new; | ||||||
|  | 
 | ||||||
|  |     new = NULL; | ||||||
|  |     if ((new = (t_fd *)malloc(sizeof(t_fd)))) | ||||||
|  |     { | ||||||
|  |         new->fd = fd; | ||||||
|  |         new->n = NULL; | ||||||
|  |         new->next = NULL; | ||||||
|  |         new->t = 0; | ||||||
|  |     } | ||||||
|  |     return (new); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static t_fd    *find_fd(int fd, t_fd **cur_fd) | ||||||
|  | { | ||||||
|  |     if (!*cur_fd) | ||||||
|  |         return ((*cur_fd = new_node(fd))); | ||||||
|  |     while ((*cur_fd)) | ||||||
|  |     { | ||||||
|  |         if ((*cur_fd)->fd == fd) | ||||||
|  |             return (*cur_fd); | ||||||
|  |         cur_fd = &((*cur_fd)->next); | ||||||
|  |     } | ||||||
|  |     return ((*cur_fd = new_node(fd))); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | int		get_next_line(const int fd, char **line) | ||||||
|  | { | ||||||
|  |     static t_fd     *head_fd; | ||||||
|  |     t_fd            *c; | ||||||
|  | 
 | ||||||
|  |     if (fd < 0 || !line) | ||||||
|  |         return (-1); | ||||||
|  |     *line = ft_strnew(0); | ||||||
|  |     c = find_fd(fd, &head_fd); | ||||||
|  |     c->readed = 0; | ||||||
|  |     if (c->n) { | ||||||
|  | 		if ((c->t = strchr(c->n, '\n')) && | ||||||
|  | 			(*line = ft_strjoin(*line, ft_strsub(c->n, 0, (c->t - c->n)))) && | ||||||
|  | 			(c->n = ++(c->t))) | ||||||
|  | 		{ | ||||||
|  | 			return (1); | ||||||
|  | 		} | ||||||
|  | 		else if ((*line = ft_strjoin(*line, c->n))) | ||||||
|  | 		{ | ||||||
|  | 			c->n = 0; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |     while ((c->readed = read(c->fd, c->b, BUFF_SIZE))) | ||||||
|  |     { | ||||||
|  |         c->b[c->readed] = 0; | ||||||
|  |         if ((c->n = strchr(c->b, '\n')) && | ||||||
|  |             (*line = ft_strjoin(*line, ft_strsub(c->b, 0, (c->n++ - c->b))))) | ||||||
|  |             break; | ||||||
|  |         *line = ft_strjoin(*line, c->b); | ||||||
|  |     } | ||||||
|  |     if (!c->readed && !ft_strlen(*line)) | ||||||
|  |         return (0); | ||||||
|  |     return (1); | ||||||
|  | } | ||||||
|  | @ -17,7 +17,17 @@ | ||||||
| # include <stdlib.h> | # include <stdlib.h> | ||||||
| # include <unistd.h> | # include <unistd.h> | ||||||
| 
 | 
 | ||||||
| # define BUF_S 1024 | # define BUFF_SIZE 100 | ||||||
|  | 
 | ||||||
|  | typedef struct  s_fd | ||||||
|  | { | ||||||
|  | 	int         fd; | ||||||
|  | 	char        b[BUFF_SIZE + 1]; | ||||||
|  | 	char        *n; | ||||||
|  | 	struct s_fd *next; | ||||||
|  | 	char        *t; | ||||||
|  | 	int         readed; | ||||||
|  | }               t_fd; | ||||||
| 
 | 
 | ||||||
| typedef struct		s_list | typedef struct		s_list | ||||||
| { | { | ||||||
|  | @ -97,5 +107,6 @@ void				*ft_realloc(void *old, unsigned int new_size, | ||||||
| 											unsigned int old_size); | 											unsigned int old_size); | ||||||
| 
 | 
 | ||||||
| char				*ft_read_file(const int fd); | char				*ft_read_file(const int fd); | ||||||
|  | int					get_next_line(const int fd, char **line); | ||||||
| 
 | 
 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
							
								
								
									
										279
									
								
								src/main.c
									
										
									
									
									
								
							
							
						
						
									
										279
									
								
								src/main.c
									
										
									
									
									
								
							|  | @ -11,12 +11,12 @@ void	swap_x_y(t_point *p1, t_point *p2) | ||||||
| { | { | ||||||
| 	int temp; | 	int temp; | ||||||
| 
 | 
 | ||||||
| 	temp = (*p1).x; | 	temp = p1->x; | ||||||
| 	(*p1).x = (*p1).y; | 	p1->x = p1->y; | ||||||
| 	(*p1).y = temp; | 	p1->y = temp; | ||||||
| 	temp = (*p2).x; | 	temp = p2->x; | ||||||
| 	(*p2).x = (*p2).y; | 	p2->x = p2->y; | ||||||
| 	(*p2).y = temp; | 	p2->y = temp; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void	swap_points(t_point *p1, t_point *p2) | void	swap_points(t_point *p1, t_point *p2) | ||||||
|  | @ -29,168 +29,181 @@ void	swap_points(t_point *p1, t_point *p2) | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void	draw_line(t_point p1, t_point p2, t_mlx m, t_swap s) | void	draw_line(t_point *p1, t_point *p2, t_mlx *m, t_swap *s) | ||||||
| { | { | ||||||
| 	int dx = abs(p2.x - p1.x); | 	int dx = abs(p2->x - p1->x); | ||||||
| 	int dy = abs(p2.y - p1.y); | 	int dy = abs(p2->y - p1->y); | ||||||
| 	int derr = 2 * dy - dx; | 	int derr = 2 * dy - dx; | ||||||
| 	while (p1.x < p2.x) | 	while (p1->x < p2->x) | ||||||
| 	{ | 	{ | ||||||
| 		if (s.swap_coord) | 		if (s->swap_coord) | ||||||
| 			mlx_pixel_put(m.mlx, m.win, p1.y, p1.x, p1.color); | 			mlx_pixel_put(m->mlx, m->win, p1->y, p1->x, p1->color); | ||||||
| 		else | 		else | ||||||
| 			mlx_pixel_put(m.mlx, m.win, p1.x, p1.y, p1.color); | 			mlx_pixel_put(m->mlx, m->win, p1->x, p1->y, p1->color); | ||||||
| 		if (derr > 0) | 		if (derr > 0) | ||||||
| 		{ | 		{ | ||||||
| 			p1.y += s.swap_x; | 			p1->y += s->swap_x; | ||||||
| 			derr -= dx; | 			derr -= dx; | ||||||
| 		} | 		} | ||||||
| 		p1.x++; | 		(p1->x)++; | ||||||
| 		derr += dy; | 		derr += dy; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void	test_line(t_mlx mlx) | void	line(t_point *p1, t_point *p2, t_mlx *m) | ||||||
| { |  | ||||||
| 	t_point p1; |  | ||||||
| 	t_point p2; |  | ||||||
| 
 |  | ||||||
| 	p1.x = 0; |  | ||||||
| 	p1.y = 0; |  | ||||||
| 	p2.x = 500; |  | ||||||
| 	p1.color = 0xC100E5; |  | ||||||
| 	p2.color = 0xC100E5; |  | ||||||
| 	for (p2.y = 0; p2.y <= 500; p2.y += 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	for (p2.x = 500; p2.x >= 0; p2.x -= 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	p1.x = 500; |  | ||||||
| 	p1.y = 0; |  | ||||||
| 	p2.x = 0; |  | ||||||
| 	p1.color = 0x1EBF00; |  | ||||||
| 	p2.color = 0x1EBF00; |  | ||||||
| 	for (p2.y = 0; p2.y <= 500; p2.y += 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	for (p2.x = 0; p2.x <= 500; p2.x += 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	p1.x = 500; |  | ||||||
| 	p1.y = 500; |  | ||||||
| 	p2.x = 500; |  | ||||||
| 	p2.y = 0; |  | ||||||
| 	p1.color = 0xFF000D; |  | ||||||
| 	p2.color = 0xFF000D; |  | ||||||
| 	for (p2.x = 500; p2.x >= 0; p2.x -= 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	for (p2.y = 0; p2.y <= 500; p2.y += 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	p1.x = 0; |  | ||||||
| 	p1.y = 500; |  | ||||||
| 	p2.x = 500; |  | ||||||
| 	p2.y = 500; |  | ||||||
| 	p1.color = 0xFAEB19; |  | ||||||
| 	p2.color = 0xFAEB19; |  | ||||||
| 	for (p2.y = 500; p2.y >= 0; p2.y -= 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	for (p2.x = 500; p2.x >= 0; p2.x -= 4) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 	} |  | ||||||
| 	mlx_clear_window(mlx.mlx, mlx.win); |  | ||||||
| 	p1.x = 0; |  | ||||||
| 	p1.y = 0; |  | ||||||
| 	p2.y = 500; |  | ||||||
| 	p1.color = 0xC100E5; |  | ||||||
| 	p2.color = 0xC100E5; |  | ||||||
| 	for (p2.x = 0; p2.x <= 500; p2.x += 1) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 		p1.x += 1; |  | ||||||
| 	} |  | ||||||
| 	mlx_clear_window(mlx.mlx, mlx.win); |  | ||||||
| 	p1.x = 0; |  | ||||||
| 	p1.y = 0; |  | ||||||
| 	p2.x = 500; |  | ||||||
| 	p1.color = 0x1EBF00; |  | ||||||
| 	p2.color = 0x1EBF00; |  | ||||||
| 	for (p2.y = 0; p2.y <= 500; p2.y += 1) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 		p1.y += 1; |  | ||||||
| 	} |  | ||||||
| 	mlx_clear_window(mlx.mlx, mlx.win); |  | ||||||
| 	p1.x = 500; |  | ||||||
| 	p1.y = 0; |  | ||||||
| 	p2.x = 500; |  | ||||||
| 	p1.color = 0xFF000D; |  | ||||||
| 	p2.color = 0xFF000D; |  | ||||||
| 	for (; p2.x >= 0; p2.x -= 1) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 		p1.x -= 1; |  | ||||||
| 	} |  | ||||||
| 	mlx_clear_window(mlx.mlx, mlx.win); |  | ||||||
| 	p1.x = 0; |  | ||||||
| 	p1.y = 500; |  | ||||||
| 	p2.x = 500; |  | ||||||
| 	p1.color = 0xFAEB19; |  | ||||||
| 	p2.color = 0xFAEB19; |  | ||||||
| 	for (p2.y = 500; p2.y >= 0; p2.y -= 1) |  | ||||||
| 	{ |  | ||||||
| 		line(p1, p2, mlx); |  | ||||||
| 		p1.y -= 1; |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void	line(t_point p1, t_point p2, t_mlx m) |  | ||||||
| { | { | ||||||
| 	int dx; | 	int dx; | ||||||
| 	int dy; | 	int dy; | ||||||
| 	t_swap swap; | 	t_swap swap; | ||||||
| 
 | 
 | ||||||
| 	dx = abs(p2.x - p1.x); | 	dx = abs(p2->x - p1->x); | ||||||
| 	dy = abs(p2.y - p1.y); | 	dy = abs(p2->y - p1->y); | ||||||
| 	swap.swap_coord = 0; | 	swap.swap_coord = 0; | ||||||
| 	swap.swap_x = 1; | 	swap.swap_x = 1; | ||||||
| 	if (dy > dx) | 	if (dy > dx) | ||||||
| 	{ | 	{ | ||||||
| 		swap_x_y(&p1, &p2); | 		swap_x_y(p1, p2); | ||||||
| 		swap.swap_coord= 1; | 		swap.swap_coord= 1; | ||||||
| 	} | 	} | ||||||
| 	if (p1.x > p2.x) | 	if (p1->x > p2->x) | ||||||
| 	{ | 	{ | ||||||
| 		swap_points(&p1, &p2); | 		swap_points(p1, p2); | ||||||
| 	} | 	} | ||||||
| 	if (p1.y > p2.y) | 	if (p1->y > p2->y) | ||||||
| 	{ | 	{ | ||||||
| 		swap.swap_x = -1; | 		swap.swap_x = -1; | ||||||
| 	} | 	} | ||||||
| 	draw_line(p1, p2, m, swap); | 	draw_line(p1, p2, m, &swap); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /* Don't work with struct pointers! */ | ||||||
|  | 
 | ||||||
|  | //void	test_line(t_mlx mlx)
 | ||||||
|  | //{
 | ||||||
|  | //	t_point p1;
 | ||||||
|  | //	t_point p2;
 | ||||||
|  | //
 | ||||||
|  | //	p1.x = 0;
 | ||||||
|  | //	p1.y = 0;
 | ||||||
|  | //	p2.x = 500;
 | ||||||
|  | //	p1.color = 0xC100E5;
 | ||||||
|  | //	p2.color = 0xC100E5;
 | ||||||
|  | //	for (p2.y = 0; p2.y <= 500; p2.y += 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	for (p2.x = 500; p2.x >= 0; p2.x -= 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	p1.x = 500;
 | ||||||
|  | //	p1.y = 0;
 | ||||||
|  | //	p2.x = 0;
 | ||||||
|  | //	p1.color = 0x1EBF00;
 | ||||||
|  | //	p2.color = 0x1EBF00;
 | ||||||
|  | //	for (p2.y = 0; p2.y <= 500; p2.y += 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	for (p2.x = 0; p2.x <= 500; p2.x += 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	p1.x = 500;
 | ||||||
|  | //	p1.y = 500;
 | ||||||
|  | //	p2.x = 500;
 | ||||||
|  | //	p2.y = 0;
 | ||||||
|  | //	p1.color = 0xFF000D;
 | ||||||
|  | //	p2.color = 0xFF000D;
 | ||||||
|  | //	for (p2.x = 500; p2.x >= 0; p2.x -= 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	for (p2.y = 0; p2.y <= 500; p2.y += 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	p1.x = 0;
 | ||||||
|  | //	p1.y = 500;
 | ||||||
|  | //	p2.x = 500;
 | ||||||
|  | //	p2.y = 500;
 | ||||||
|  | //	p1.color = 0xFAEB19;
 | ||||||
|  | //	p2.color = 0xFAEB19;
 | ||||||
|  | //	for (p2.y = 500; p2.y >= 0; p2.y -= 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	for (p2.x = 500; p2.x >= 0; p2.x -= 4)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //	}
 | ||||||
|  | //	mlx_clear_window(mlx.mlx, mlx.win);
 | ||||||
|  | //	p1.x = 0;
 | ||||||
|  | //	p1.y = 0;
 | ||||||
|  | //	p2.y = 500;
 | ||||||
|  | //	p1.color = 0xC100E5;
 | ||||||
|  | //	p2.color = 0xC100E5;
 | ||||||
|  | //	for (p2.x = 0; p2.x <= 500; p2.x += 1)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //		p1.x += 1;
 | ||||||
|  | //	}
 | ||||||
|  | //	mlx_clear_window(mlx.mlx, mlx.win);
 | ||||||
|  | //	p1.x = 0;
 | ||||||
|  | //	p1.y = 0;
 | ||||||
|  | //	p2.x = 500;
 | ||||||
|  | //	p1.color = 0x1EBF00;
 | ||||||
|  | //	p2.color = 0x1EBF00;
 | ||||||
|  | //	for (p2.y = 0; p2.y <= 500; p2.y += 1)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //		p1.y += 1;
 | ||||||
|  | //	}
 | ||||||
|  | //	mlx_clear_window(mlx.mlx, mlx.win);
 | ||||||
|  | //	p1.x = 500;
 | ||||||
|  | //	p1.y = 0;
 | ||||||
|  | //	p2.x = 500;
 | ||||||
|  | //	p1.color = 0xFF000D;
 | ||||||
|  | //	p2.color = 0xFF000D;
 | ||||||
|  | //	for (; p2.x >= 0; p2.x -= 1)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //		p1.x -= 1;
 | ||||||
|  | //	}
 | ||||||
|  | //	mlx_clear_window(mlx.mlx, mlx.win);
 | ||||||
|  | //	p1.x = 0;
 | ||||||
|  | //	p1.y = 500;
 | ||||||
|  | //	p2.x = 500;
 | ||||||
|  | //	p1.color = 0xFAEB19;
 | ||||||
|  | //	p2.color = 0xFAEB19;
 | ||||||
|  | //	for (p2.y = 500; p2.y >= 0; p2.y -= 1)
 | ||||||
|  | //	{
 | ||||||
|  | //		line(&p1, &p2, &mlx);
 | ||||||
|  | //		p1.y -= 1;
 | ||||||
|  | //	}
 | ||||||
|  | //}
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| int		main(int argc, char **argv) | int		main(int argc, char **argv) | ||||||
| { | { | ||||||
| 	t_mlx m; | 	t_mlx	m; | ||||||
|  | 	int 	fd; | ||||||
|  | 	char 	*line; | ||||||
| 
 | 
 | ||||||
| 	argc = argc + 1; | 	if (argc != 2) | ||||||
| 	argv = argv; | 	{ | ||||||
|  | 		return (0); | ||||||
|  | 	} | ||||||
|  | 	fd = open(argv[1], O_RDONLY); | ||||||
|  | 	while (get_next_line(fd, &line)) | ||||||
|  | 	{ | ||||||
|  | 		ft_putstr(line); | ||||||
|  | 		ft_putstr("\n"); | ||||||
|  | 	} | ||||||
| 	m.mlx = mlx_init(); | 	m.mlx = mlx_init(); | ||||||
| 	m.win = mlx_new_window(m.mlx, 500, 500, "fdf"); | 	m.win = mlx_new_window(m.mlx, 500, 500, "fdf"); | ||||||
| 	//line(p1, p2, m);
 | 	//line(&p1, &p2, &m);
 | ||||||
| 	test_line(m); | 	//test_line(m);
 | ||||||
| 	mlx_loop(m.mlx); | 	mlx_loop(m.mlx); | ||||||
| 	return (0); | 	return (0); | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Gregory
						Gregory