repare parseur avec probleme malloc
This commit is contained in:
Binary file not shown.
Binary file not shown.
6
Makefile
6
Makefile
@@ -6,14 +6,14 @@
|
|||||||
# By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ #
|
# By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ #
|
||||||
# +#+#+#+#+#+ +#+ #
|
# +#+#+#+#+#+ +#+ #
|
||||||
# Created: 2019/03/01 13:24:35 by vmanzoni #+# #+# #
|
# Created: 2019/03/01 13:24:35 by vmanzoni #+# #+# #
|
||||||
# Updated: 2019/04/15 20:17:47 by vmanzoni ### ########.fr #
|
# Updated: 2019/04/16 14:05:39 by hulamy ### ########.fr #
|
||||||
# #
|
# #
|
||||||
# **************************************************************************** #
|
# **************************************************************************** #
|
||||||
|
|
||||||
NAME = fillit
|
NAME = fillit
|
||||||
|
|
||||||
OBJ_DIR = objs/
|
OBJ_DIR = ./
|
||||||
HEADER = includes/
|
HEADER = ./
|
||||||
|
|
||||||
SRCS = *.c
|
SRCS = *.c
|
||||||
OBJS = $(SRCS:.c=.o)
|
OBJS = $(SRCS:.c=.o)
|
||||||
|
|||||||
@@ -6,7 +6,7 @@
|
|||||||
/* By: hulamy <hulamy@student.42.fr> +#+ +:+ +#+ */
|
/* By: hulamy <hulamy@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/04/14 15:20:53 by hulamy #+# #+# */
|
/* Created: 2019/04/14 15:20:53 by hulamy #+# #+# */
|
||||||
/* Updated: 2019/04/15 20:49:33 by vmanzoni ### ########.fr */
|
/* Updated: 2019/04/16 15:32:14 by hulamy ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@@ -29,7 +29,7 @@ char **fill_tetraminos(char **square, int *tab)
|
|||||||
i = 0;
|
i = 0;
|
||||||
height = tab[2] - tab[0] + 1;
|
height = tab[2] - tab[0] + 1;
|
||||||
length = tab[3] - tab[1] + 1;
|
length = tab[3] - tab[1] + 1;
|
||||||
if (!(result = (char**)malloc(sizeof(*result) * (height))))
|
if (!(result = (char**)malloc(sizeof(*result) * (height + 1))))
|
||||||
return (NULL);
|
return (NULL);
|
||||||
while (i < height)
|
while (i < height)
|
||||||
{
|
{
|
||||||
@@ -128,25 +128,25 @@ int add_to_list(char **square, t_fillist **list)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
int main(int ac, char **av)
|
**int main(int ac, char **av)
|
||||||
{
|
**{
|
||||||
static t_fillist *list = NULL; // avant d'appeller add_to_list il faut declarer un pointeur static vers la structure
|
** static t_fillist *list = NULL; // avant d'appeller add_to_list il faut declarer un pointeur static vers la structure
|
||||||
int i;
|
** int i;
|
||||||
|
**
|
||||||
if (ac > 1)
|
** if (ac > 1)
|
||||||
{
|
** {
|
||||||
add_to_list(++av, &list); // l'appel de la fonction se fait avec un carre valide de 4*4 et l'adresse du pointeur vers la liste
|
** add_to_list(++av, &list); // l'appel de la fonction se fait avec un carre valide de 4*4 et l'adresse du pointeur vers la liste
|
||||||
if (ac == 9)
|
** if (ac == 9)
|
||||||
add_to_list(av += 4, &list);
|
** add_to_list(av += 4, &list);
|
||||||
while (list && (i = -1))
|
** while (list && (i = -1))
|
||||||
{
|
** {
|
||||||
while (++i < list->size[1])
|
** while (++i < list->size[1])
|
||||||
printf("%s\n", list->tetraminos[i]);
|
** printf("%s\n", list->tetraminos[i]);
|
||||||
printf("\n");
|
** printf("\n");
|
||||||
list = list->next;
|
** list = list->next;
|
||||||
}
|
** }
|
||||||
}
|
** }
|
||||||
|
**
|
||||||
return (0);
|
** return (0);
|
||||||
}
|
**}
|
||||||
*/
|
*/
|
||||||
|
|||||||
BIN
add_to_list.o
BIN
add_to_list.o
Binary file not shown.
Binary file not shown.
BIN
handle_errors.o
BIN
handle_errors.o
Binary file not shown.
@@ -6,7 +6,7 @@
|
|||||||
/* By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ */
|
/* By: vmanzoni <vmanzoni@student.42.fr> +#+ +:+ +#+ */
|
||||||
/* +#+#+#+#+#+ +#+ */
|
/* +#+#+#+#+#+ +#+ */
|
||||||
/* Created: 2019/04/15 14:48:14 by vmanzoni #+# #+# */
|
/* Created: 2019/04/15 14:48:14 by vmanzoni #+# #+# */
|
||||||
/* Updated: 2019/04/16 11:50:45 by vmanzoni ### ########.fr */
|
/* Updated: 2019/04/16 15:28:11 by hulamy ### ########.fr */
|
||||||
/* */
|
/* */
|
||||||
/* ************************************************************************** */
|
/* ************************************************************************** */
|
||||||
|
|
||||||
@@ -18,24 +18,23 @@
|
|||||||
|
|
||||||
char **create_square(char *tetri)
|
char **create_square(char *tetri)
|
||||||
{
|
{
|
||||||
char **square = NULL;
|
char **square;
|
||||||
int i;
|
int i;
|
||||||
int k;
|
int k;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
while (tetri[i])
|
if (!(square = (char**)malloc(sizeof(*square) * 4)))
|
||||||
|
return (NULL);
|
||||||
|
while (*tetri && (k = -1))
|
||||||
{
|
{
|
||||||
k = 0;
|
if (!(square[i] = (char*)malloc(sizeof(**square) * (4 + 1))))
|
||||||
*square = malloc((sizeof(char)*4) + 1);
|
return (NULL);
|
||||||
while (k < 4)
|
square[i][4] = '\0';
|
||||||
{
|
while (++k < 4)
|
||||||
*square[k] = tetri[i];
|
square[i][k] = *(tetri++);
|
||||||
k++;
|
while (*tetri == '\n')
|
||||||
i++;
|
tetri++;
|
||||||
}
|
// printf("%s\n", square[i]);
|
||||||
i++;
|
|
||||||
//printf("print:\n%s\n", *square);
|
|
||||||
while (tetri[i] == '\n')
|
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
return (square);
|
return (square);
|
||||||
@@ -47,6 +46,7 @@ void parse_input(char *input)
|
|||||||
char tetri[20];
|
char tetri[20];
|
||||||
int i;
|
int i;
|
||||||
int j;
|
int j;
|
||||||
|
char **test;
|
||||||
|
|
||||||
i = 0;
|
i = 0;
|
||||||
while (input[i])
|
while (input[i])
|
||||||
@@ -58,8 +58,20 @@ void parse_input(char *input)
|
|||||||
//printf("PRINT:\n%s\n", tetri);
|
//printf("PRINT:\n%s\n", tetri);
|
||||||
if (check_tetri_errors(tetri))
|
if (check_tetri_errors(tetri))
|
||||||
print_error("Error: Tetrimino not valid.");
|
print_error("Error: Tetrimino not valid.");
|
||||||
add_to_list(create_square(tetri), &list);
|
test = create_square(tetri);
|
||||||
|
add_to_list(test, &list);
|
||||||
while (input[i] == '\n')
|
while (input[i] == '\n')
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
** ce qui suit sert juste a afficher le contenu de tous les tetraminos de la liste chainee
|
||||||
|
** pour debug, a effacer au rendu
|
||||||
|
*/
|
||||||
|
while (list && (i = -1))
|
||||||
|
{
|
||||||
|
while (++i < list->size[1])
|
||||||
|
printf("%s\n", list->tetraminos[i]);
|
||||||
|
printf("\n");
|
||||||
|
list = list->next;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
BIN
print_fillit.o
BIN
print_fillit.o
Binary file not shown.
Reference in New Issue
Block a user