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