示例#1
0
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);
}
示例#2
0
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);
}