First commit, few files added

This commit is contained in:
Manzovince
2019-04-12 22:01:24 +02:00
parent d54cce63cc
commit ae309ef6aa
7 changed files with 209 additions and 1 deletions

61
srcs/handle_errors.c Normal file
View File

@@ -0,0 +1,61 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* handle_errors.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2019/03/01 13:29:05 by vmanzoni #+# #+# */
/* Updated: 2019/03/01 13:39:00 by vmanzoni ### ########.fr */
/* */
/* ************************************************************************** */
void ft_display_error(char *s, int fd)
{
write(fd, s, strlen(s));
}
static bool ft_tetri_errors(char tetri[16])
{
short i;
short links_nb;
short tetri_blocks;
bool all_blocks_connected;
i = 0;
tetri_blocks = 0;
while (i < 16)
{
if (tetri[i] == '#')
{
links_nb = 0; // reset links_nb to 0
links_nb += (i % 4 != 0 && (tetri[i - 1] == '#')); // if not first column
links_nb += (i % 4 != 3 && (tetri[i + 1] == '#')); // if not last column
links_nb += (i / 4 != 0 && (tetri[i - 4] == '#')); // if not first row
links_nb += (i / 4 != 3 && (tetri[i + 4] == '#')); // if not last row
if (links_nb == 0)
return false;
if (links_nb > 1)
all_blocks_connected = true;
++tetri_blocks;
}
++i;
}
return (tetri_blocks == 4 && all_blocks_connected);
}
bool ft_check_tetri(short tetri_nb, char tetri[tetri_nb][16])
{
short count;
count = 0;
while (count < tetri_nb)
{
if (ft_tetri_errors(tetri[count++]) == false)
{
ft_display_error("Tetriminos is invalid.\n", 2);
return false;
}
}
return true;
}

35
srcs/main.c Normal file
View File

@@ -0,0 +1,35 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* main.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2019/02/12 13:20:48 by vmanzoni #+# #+# */
/* Updated: 2019/04/12 22:00:34 by vmanzoni ### ########.fr */
/* */
/* ************************************************************************** */
int main(int argc, char **argv)
{
char *input;
short i;
if (argc == 2)
{
if (!(input = read_file(argv[1])))
ft_display_error("Error: Could not read file.\n", 2);
else if (/*Elements in file not valid*/)
ft_display_error("Error: Invalid file.\n", 2);
/*
Transform input to tetriminos
Check if every tetrimino is valid
Backtracking for smallest square
Transform tetriminos with letters
Print result
*/
}
else
ft_display_error("Error: Please submit a file.\n", 2);
return 0;
}

31
srcs/print_fillit.c Normal file
View File

@@ -0,0 +1,31 @@
/* ************************************************************************** */
/* */
/* ::: :::::::: */
/* print_fillit.c :+: :+: :+: */
/* +:+ +:+ +:+ */
/* By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2019/03/01 13:35:48 by vmanzoni #+# #+# */
/* Updated: 2019/03/01 13:37:45 by vmanzoni ### ########.fr */
/* */
/* ************************************************************************** */
void ft_print_fillit(short tetri_nb, char tetri[tetri_nb][16])
{
short count;
short i;
count = 0;
while (count < tetri_nb)
{
i = 0;
while (i < 16)
{
write(1, &tetri[count][i], 1);
if (i++ % 4 == 3)
write(1, "\n", 1);
}
write(1, "\n", 1);
++count;
}
}