5 * Miguel de Icaza (miguel@novell.com)
6 * Aaron Bockover (abockover@novell.com)
8 * (C) 2006 Novell, Inc.
10 * Permission is hereby granted, free of charge, to any person obtaining
11 * a copy of this software and associated documentation files (the
12 * "Software"), to deal in the Software without restriction, including
13 * without limitation the rights to use, copy, modify, merge, publish,
14 * distribute, sublicense, and/or sell copies of the Software, and to
15 * permit persons to whom the Software is furnished to do so, subject to
16 * the following conditions:
18 * The above copyright notice and this permission notice shall be
19 * included in all copies or substantial portions of the Software.
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
25 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
27 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
33 #define GROW_IF_NECESSARY(s,l) { \
34 if(s->len + l >= s->allocated_len) { \
35 s->allocated_len = (s->allocated_len + l + 16) * 2; \
36 s->str = g_realloc(s->str, s->allocated_len); \
41 g_string_new_len (const gchar *init, gssize len)
43 GString *ret = g_new (GString, 1);
45 ret->len = len < 0 ? strlen(init) : len;
46 ret->allocated_len = MAX(ret->len + 1, 16);
47 ret->str = g_malloc(ret->allocated_len);
48 memcpy(ret->str, init, ret->len);
49 ret->str[ret->len] = 0;
55 g_string_new (const gchar *init)
57 return g_string_new_len(init, -1);
61 g_string_sized_new (gsize default_size)
63 GString *ret = g_new (GString, 1);
65 ret->str = g_malloc (default_size);
68 ret->allocated_len = default_size;
74 g_string_free (GString *string, gboolean free_segment)
78 g_return_val_if_fail (string != NULL, NULL);
92 g_string_append_len (GString *string, const gchar *val, gssize len)
94 g_return_val_if_fail(string != NULL, NULL);
95 g_return_val_if_fail(val != NULL, string);
101 GROW_IF_NECESSARY(string, len);
102 memcpy(string->str + string->len, val, len);
104 string->str[string->len] = 0;
110 g_string_append (GString *string, const gchar *val)
112 g_return_val_if_fail(string != NULL, NULL);
113 g_return_val_if_fail(val != NULL, string);
115 return g_string_append_len(string, val, -1);
119 g_string_append_c (GString *string, gchar c)
121 g_return_val_if_fail(string != NULL, NULL);
123 GROW_IF_NECESSARY(string, 1);
125 string->str[string->len] = c;
126 string->str[string->len + 1] = 0;
133 g_string_prepend (GString *string, const gchar *val)
137 g_return_val_if_fail (string != NULL, string);
138 g_return_val_if_fail (val != NULL, string);
142 GROW_IF_NECESSARY(string, len);
143 memmove(string->str + len, string->str, string->len + 1);
144 memcpy(string->str, val, len);
150 g_string_append_printf (GString *string, const gchar *format, ...)
155 g_return_if_fail (string != NULL);
156 g_return_if_fail (format != NULL);
158 va_start (args, format);
159 ret = g_strdup_vprintf (format, args);
161 g_string_append (string, ret);
167 g_string_printf (GString *string, const gchar *format, ...)
171 g_return_if_fail (string != NULL);
172 g_return_if_fail (format != NULL);
174 g_free (string->str);
176 va_start (args, format);
177 string->str = g_strdup_vprintf (format, args);
180 string->len = strlen (string->str);
181 string->allocated_len = string->len+1;
185 g_string_truncate (GString *string, gsize len)
187 g_return_val_if_fail (string != NULL, string);
190 if (len < 0 || len >= string->len) {
195 string->str[len] = 0;