t_list* npi_manage_operator(char** expr_tab, char* token, int* ind, t_list* stack, char* operators) { char* list_token; char op; char* temp; if(stack != 0) { temp = stack->data; op = *temp; } if(my_list_size(stack) == 0) stack = my_list_add(token, stack); else if(is_parenthesis(op, operators, 1)) stack = my_list_add(token, stack); else if(is_operator_prioritary(*token, op, operators)) stack = my_list_add(token, stack); else { list_token = my_list_pop(&stack); expr_tab[*ind] = list_token; (*ind)++; stack = my_list_add(token, stack); } return (stack); }
void test_list(void) { struct my_list* list; struct my_list_item* item; struct my_list_item* item1; struct my_list_item* item2; int i; list = my_list_new(); for (i = 0; i < 10; i++) { item = my_list_item_new(); item->a = i; item->b = i * i; my_list_enqueue(list, item); } for (i = 0, item = list->head; item; i++, item = my_list_item_next(item)) { CU_ASSERT(item->a == i); CU_ASSERT(item->b == i * i); /*printf("%d %d\n", item->a, item->b);*/ } item1 = my_list_item_new(); my_list_add(list, item1); item2 = my_list_item_new(); my_list_add(list, item2); CU_ASSERT(my_list_remove(list, item1) == item1); my_list_item_free(item1); CU_ASSERT(my_list_remove(list, item2) == item2); CU_ASSERT(my_list_remove(list, item2) == NULL); my_list_item_free(item2); my_list_free(list); }