/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description:
*
*/
#undef G_DISABLE_ASSERT
#undef G_LOG_DOMAIN
#include <stdio.h>
#include <string.h>
#include "glib.h"
#ifdef __SYMBIAN32__
#include "mrt2_glib2_test.h"
#endif /*__SYMBIAN32__*/
int main (int argc,char *argv[])
{
GList *list1 = NULL,*list2 = NULL,*l,*l1,*list3 = NULL;
int i;
int *value;
const char mem_allocator[] = "mem_allocator";
GAllocator *allocator;
int num1[] =
{
1,2,3
};
int num2[] =
{
4,5,6
};
#ifdef __SYMBIAN32__
g_log_set_handler (NULL, G_LOG_FLAG_FATAL| G_LOG_FLAG_RECURSION | G_LOG_LEVEL_CRITICAL | G_LOG_LEVEL_WARNING | G_LOG_LEVEL_MESSAGE | G_LOG_LEVEL_INFO | G_LOG_LEVEL_DEBUG, &mrtLogHandler, NULL);
#endif /*__SYMBIAN32__*/
allocator = g_allocator_new(mem_allocator,500);
for(i=0;i<3;i++)
list1 = g_list_append (list1, &num1[i]);
for(i=0;i<3;i++)
list2 = g_list_append (list2, &num2[i]);
list1 = g_list_concat(list1,list2);
for(i=0;i<6;i++)
{
l = g_list_nth(list1,i);
g_assert(*(gint *)(l->data) == i+1);
}
list2 = g_list_copy(list1);
for(i=0;i<3;i++)
{
l = g_list_nth(list2,i);
g_assert(*(gint *)(l->data) == i+1);
}
l = g_list_first(list2);
g_assert(*(gint *)(l->data) == 1);
value = (int *)g_list_nth_data(list1,1);
g_assert(*value == 2);
l = g_list_nth(list1,3);
l1 = g_list_nth_prev(l,2);
for(i=0;i<5;i++)
{
l = g_list_nth(l1,i);
g_assert(*(gint *)(l->data) == i+2);
}
g_list_push_allocator(allocator);
list3 = g_list_append(list3,&num1[2]);
g_assert(*(gint *)(list3->data) == 3);
g_list_pop_allocator();
list3 = g_list_append(list3,&num1[0]);
g_assert(*(gint *)(list3->next->data) == 1);
list1 = g_list_append(list1,&num1[0]);
i = g_list_length(list1);
list1 = g_list_remove_all(list1,&num1[0]);
i = g_list_length(list1);
g_assert(g_list_length(list1) == 5); // should be this value as we will remove 2 1's from the list
for(i==0;i<g_list_length(list1);i++)
{
l = g_list_nth(list1,i);
g_assert(*(gint *)(l->data) != 1);
}
g_allocator_free(allocator);
#ifdef __SYMBIAN32__
testResultXml("list_test");
#endif /* EMULATOR */
return 0;
}