-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathft_putblock.c
More file actions
81 lines (74 loc) · 1.98 KB
/
ft_putblock.c
File metadata and controls
81 lines (74 loc) · 1.98 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* ft_putblock.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: akaseris <marvin@42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2017/12/07 15:12:24 by akaseris #+# #+# */
/* Updated: 2017/12/20 13:10:44 by jszabo ### ########.fr */
/* */
/* ************************************************************************** */
#include "fillit.h"
static char **ft_fillgrid(char **grid, t_tet *a, int i, int j)
{
int k;
k = 0;
grid[i][j] = a->c;
a = a->next;
while (k < 3)
{
grid[i + a->y][j + a->x] = a->c;
k++;
a = a->next;
}
return (grid);
}
static t_tet *ft_isblockfit(t_tet *blocks, char **grid, int i, int j)
{
char c;
int len;
t_tet *tmp;
c = blocks->c;
tmp = blocks;
blocks = blocks->next;
len = 0;
while (grid[len])
len++;
while (blocks && blocks->c == c)
{
if ((i + blocks->y > len - 1) || (j + blocks->x > len - 1)
|| grid[i + blocks->y][j + blocks->x] != '.')
break ;
blocks = blocks->next;
}
if (!blocks || blocks->c != c)
grid = ft_fillgrid(grid, tmp, i, j);
return (blocks);
}
int ft_putblock(t_tet *blocks, char **grid, int ign)
{
int i;
int j;
t_tet *tmp;
i = 0;
while (grid[i])
{
j = 0;
while (grid[i][j])
{
if (grid[i][j] == '.')
{
tmp = blocks;
blocks = (!ign) ? ft_isblockfit(blocks, grid, i, j) : blocks;
if (!ign && (!blocks || blocks->c != tmp->c))
return (1);
ign = (ign) ? ign - 1 : ign;
blocks = tmp;
}
j++;
}
i++;
}
return (0);
}