Add GRegex for regular expression matching. (#50075)
[platform/upstream/glib.git] / tests / array-test.c
1 /* GLIB - Library of useful routines for C programming
2  * Copyright (C) 1995-1997  Peter Mattis, Spencer Kimball and Josh MacDonald
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with this library; if not, write to the
16  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17  * Boston, MA 02111-1307, USA.
18  */
19
20 /*
21  * Modified by the GLib Team and others 1997-2000.  See the AUTHORS
22  * file for a list of people on the GLib Team.  See the ChangeLog
23  * files for a list of changes.  These files are distributed with
24  * GLib at ftp://ftp.gtk.org/pub/gtk/. 
25  */
26
27 #undef G_DISABLE_ASSERT
28 #undef G_LOG_DOMAIN
29
30 #include <stdio.h>
31 #include <string.h>
32 #include "glib.h"
33
34 static void 
35 sum_up (gpointer data, 
36         gpointer user_data)
37 {
38   gint *sum = (gint *)user_data;
39
40   *sum += GPOINTER_TO_INT (data);
41 }
42
43 int
44 main (int   argc,
45       char *argv[])
46 {
47   gint i;
48   GArray *garray;
49   GPtrArray *gparray;
50   GByteArray *gbarray;
51   gint sum = 0;
52
53   /* array tests */
54   garray = g_array_new (FALSE, FALSE, sizeof (gint));
55   for (i = 0; i < 10000; i++)
56     g_array_append_val (garray, i);
57
58   for (i = 0; i < 10000; i++)
59     g_assert (g_array_index (garray, gint, i) == i);
60
61   g_array_free (garray, TRUE);
62
63   garray = g_array_new (FALSE, FALSE, sizeof (gint));
64   for (i = 0; i < 100; i++)
65     g_array_prepend_val (garray, i);
66
67   for (i = 0; i < 100; i++)
68     g_assert (g_array_index (garray, gint, i) == (100 - i - 1));
69
70   g_array_free (garray, TRUE);
71
72   /* pointer arrays */
73   gparray = g_ptr_array_new ();
74   for (i = 0; i < 10000; i++)
75     g_ptr_array_add (gparray, GINT_TO_POINTER (i));
76
77   for (i = 0; i < 10000; i++)
78     if (g_ptr_array_index (gparray, i) != GINT_TO_POINTER (i))
79       g_print ("array fails: %p ( %p )\n",
80                g_ptr_array_index (gparray, i),
81                GINT_TO_POINTER (i));
82   
83   g_ptr_array_foreach (gparray, sum_up, &sum);
84   g_assert (sum == 49995000);
85
86   g_ptr_array_free (gparray, TRUE);
87
88   /* byte arrays */
89   gbarray = g_byte_array_new ();
90   for (i = 0; i < 10000; i++)
91     g_byte_array_append (gbarray, (guint8*) "abcd", 4);
92
93   for (i = 0; i < 10000; i++)
94     {
95       g_assert (gbarray->data[4*i] == 'a');
96       g_assert (gbarray->data[4*i+1] == 'b');
97       g_assert (gbarray->data[4*i+2] == 'c');
98       g_assert (gbarray->data[4*i+3] == 'd');
99     }
100
101   g_byte_array_free (gbarray, TRUE);
102
103   return 0;
104 }
105