corrige le fill_list pour virer les zeros de debut de tetraminos
This commit is contained in:
137
add_to_list.c
137
add_to_list.c
@@ -6,28 +6,27 @@
|
||||
/* By: hulamy <hulamy@student.42.fr> +#+ +:+ +#+ */
|
||||
/* +#+#+#+#+#+ +#+ */
|
||||
/* Created: 2019/04/14 15:20:53 by hulamy #+# #+# */
|
||||
/* Updated: 2019/04/24 12:15:47 by hulamy ### ########.fr */
|
||||
/* Updated: 2019/04/24 13:38:22 by hulamy ### ########.fr */
|
||||
/* */
|
||||
/* ************************************************************************** */
|
||||
|
||||
#include "fillit.h"
|
||||
#include <stdio.h>
|
||||
//#include "libft/includes/libft.h"
|
||||
//#include <stdio.h>
|
||||
|
||||
/*
|
||||
** DELETE BEFORE EVAL - TEST FUNCTION
|
||||
** Function that prints a 16 bites short
|
||||
*/
|
||||
|
||||
void print_bits(short line)
|
||||
{
|
||||
int mask;
|
||||
|
||||
mask = 1 << 27;
|
||||
while (mask >>= 1)
|
||||
(line & mask) ? write(1, "1", 1) : write(1, "0", 1);
|
||||
write(1, "\n", 1);
|
||||
}
|
||||
//void print_bits(short line)
|
||||
//{
|
||||
// int mask;
|
||||
//
|
||||
// mask = 1 << 16;
|
||||
// while (mask >>= 1)
|
||||
// (line & mask) ? write(1, "1", 1) : write(1, "0", 1);
|
||||
// write(1, "\n", 1);
|
||||
//}
|
||||
|
||||
/*
|
||||
** Function that transforme a tetrminos char* into a short of 16 bites
|
||||
@@ -36,8 +35,8 @@ void print_bits(short line)
|
||||
|
||||
int fill_list(char line[], t_fillist *list)
|
||||
{
|
||||
// short tmp;
|
||||
int i;
|
||||
unsigned short tmp;
|
||||
int i;
|
||||
|
||||
i = 0;
|
||||
while (line[i])
|
||||
@@ -48,15 +47,16 @@ int fill_list(char line[], t_fillist *list)
|
||||
if (line[i++] == '#')
|
||||
list->tetribit |= 1;
|
||||
}
|
||||
// tmp = list->tetribit;
|
||||
// while (tmp)
|
||||
// {
|
||||
// if (tmp & 1)
|
||||
// list->tibirtet |= 1;
|
||||
// list->tibirtet <<= 1;
|
||||
// tmp >>= 1;
|
||||
// }
|
||||
print_bits(list->tetribit);
|
||||
while (!(list->tetribit & (1 << 15)))
|
||||
list->tetribit <<= 1;
|
||||
tmp = list->tetribit;
|
||||
while (tmp)
|
||||
{
|
||||
list->tibirtet <<= 1;
|
||||
if (tmp & 1)
|
||||
list->tibirtet |= 1;
|
||||
tmp >>= 1;
|
||||
}
|
||||
return (0);
|
||||
}
|
||||
|
||||
@@ -80,81 +80,26 @@ int add_to_list(char *line, t_fillist **list)
|
||||
return (1);
|
||||
}
|
||||
|
||||
/*
|
||||
** DELETE BEFORE EVAL - TEST FUNCTION
|
||||
** Print octet
|
||||
*/
|
||||
|
||||
void print_test(int octet)
|
||||
{
|
||||
unsigned int i;
|
||||
|
||||
i = 1 << 31;
|
||||
while (i)
|
||||
{
|
||||
(octet & i) ? printf("1") : printf("0");
|
||||
i >>= 1;
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
** DELETE BEFORE EVAL - TEST FUNCTION
|
||||
** Test for big map
|
||||
*/
|
||||
|
||||
void test(unsigned int map[])
|
||||
{
|
||||
int i;
|
||||
int j;
|
||||
int k;
|
||||
int l;
|
||||
unsigned int mask;
|
||||
|
||||
mask = map[9];
|
||||
|
||||
i = -1;
|
||||
j = 9;
|
||||
while (j >= 0)
|
||||
{
|
||||
if (!(++i % 32) && j-- && (k = -1))
|
||||
{
|
||||
while (++k < 10)
|
||||
print_test(map[k]);
|
||||
printf("\n");
|
||||
}
|
||||
l = 0;
|
||||
while (l++ < 320 - 32 - i)
|
||||
printf(" ");
|
||||
print_test(mask);
|
||||
printf("\n");
|
||||
mask = (mask >> 1) | (((1 << (i % 32)) & map[j]) << (31 - (i % 32)));
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
** DELETE BEFORE EVAL - MAIN FOR TEST
|
||||
*/
|
||||
|
||||
/*
|
||||
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
|
||||
unsigned int map[10] = {1568713153, 817645681, 654186132, 538171355, 1718453135, 551286515, 1631843343, 3413834313, 1155555555, 999999999};
|
||||
int i;
|
||||
//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
|
||||
// int i;
|
||||
//
|
||||
// if (ac > 1)
|
||||
// {
|
||||
// add_to_list(*(++av), &list);
|
||||
// while (list && (i = -1))
|
||||
// {
|
||||
// printf("%d\n", list->tetribit);
|
||||
// print_bits(list->tetribit);
|
||||
// print_bits(list->tibirtet);
|
||||
// list = list->next;
|
||||
// }
|
||||
// }
|
||||
// return (0);
|
||||
//}
|
||||
|
||||
if (ac > 1)
|
||||
{
|
||||
add_to_list(*(++av), &list);
|
||||
while (list && (i = -1))
|
||||
{
|
||||
printf("%d\n", list->tetribit);
|
||||
print_bits(list->tetribit);
|
||||
print_bits(list->tibirtet);
|
||||
list = list->next;
|
||||
}
|
||||
}
|
||||
test(map);
|
||||
|
||||
return (0);
|
||||
}
|
||||
*/
|
||||
|
||||
Reference in New Issue
Block a user