[glib] GKeyFile: remove approximate_size optimisation
- From: Ryan Lortie <ryanl src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib] GKeyFile: remove approximate_size optimisation
- Date: Tue, 24 Jan 2012 22:17:45 +0000 (UTC)
commit fe10b2c966289d87ea6ea6e76e1ae87ba16f101b
Author: Ryan Lortie <desrt desrt ca>
Date: Tue Jan 24 16:45:49 2012 -0500
GKeyFile: remove approximate_size optimisation
This is micro-optimisation of the worst kind and it's causing obscure
bugs in edge cases. Better just remove this entirely.
https://bugzilla.gnome.org/show_bug.cgi?id=634232
glib/gkeyfile.c | 40 +++++++---------------------------------
1 files changed, 7 insertions(+), 33 deletions(-)
---
diff --git a/glib/gkeyfile.c b/glib/gkeyfile.c
index 8de05a2..440cc56 100644
--- a/glib/gkeyfile.c
+++ b/glib/gkeyfile.c
@@ -438,9 +438,6 @@ struct _GKeyFile
GString *parse_buffer; /* Holds up to one line of not-yet-parsed data */
- /* Used for sizing the output buffer during serialization */
- gsize approximate_size;
-
gchar list_separator;
GKeyFileFlags flags;
@@ -573,7 +570,6 @@ g_key_file_init (GKeyFile *key_file)
key_file->group_hash = g_hash_table_new (g_str_hash, g_str_equal);
key_file->start_group = NULL;
key_file->parse_buffer = g_string_sized_new (128);
- key_file->approximate_size = 0;
key_file->list_separator = ';';
key_file->flags = 0;
key_file->locales = g_strdupv ((gchar **)g_get_language_names ());
@@ -766,11 +762,8 @@ g_key_file_load_from_fd (GKeyFile *key_file,
return FALSE;
}
- if (key_file->approximate_size > 0)
- {
- g_key_file_clear (key_file);
- g_key_file_init (key_file);
- }
+ g_key_file_clear (key_file);
+ g_key_file_init (key_file);
key_file->flags = flags;
do
@@ -894,11 +887,8 @@ g_key_file_load_from_data (GKeyFile *key_file,
if (length == (gsize)-1)
length = strlen (data);
- if (key_file->approximate_size > 0)
- {
- g_key_file_clear (key_file);
- g_key_file_init (key_file);
- }
+ g_key_file_clear (key_file);
+ g_key_file_init (key_file);
key_file->flags = flags;
g_key_file_parse_data (key_file, data, length, &key_file_error);
@@ -1408,8 +1398,6 @@ g_key_file_parse_data (GKeyFile *key_file,
i += line_length;
}
}
-
- key_file->approximate_size += length;
}
static void
@@ -1465,8 +1453,8 @@ g_key_file_to_data (GKeyFile *key_file,
g_return_val_if_fail (key_file != NULL, NULL);
- data_string = g_string_sized_new (2 * key_file->approximate_size);
-
+ data_string = g_string_new (NULL);
+
for (group_node = g_list_last (key_file->groups);
group_node != NULL;
group_node = group_node->prev)
@@ -3255,9 +3243,6 @@ g_key_file_set_comment (GKeyFile *key_file,
return FALSE;
}
- if (comment != NULL)
- key_file->approximate_size += strlen (comment);
-
return TRUE;
}
@@ -3631,7 +3616,6 @@ g_key_file_add_group (GKeyFile *key_file,
group->name = g_strdup (group_name);
group->lookup_map = g_hash_table_new (g_str_hash, g_str_equal);
key_file->groups = g_list_prepend (key_file->groups, group);
- key_file->approximate_size += strlen (group_name) + 3;
key_file->current_group = group;
if (key_file->start_group == NULL)
@@ -3672,11 +3656,7 @@ g_key_file_remove_key_value_pair_node (GKeyFile *key_file,
group->key_value_pairs = g_list_remove_link (group->key_value_pairs, pair_node);
- if (pair->key != NULL)
- key_file->approximate_size -= strlen (pair->key) + 1;
-
g_warn_if_fail (pair->value != NULL);
- key_file->approximate_size -= strlen (pair->value);
g_key_file_key_value_pair_free (pair);
@@ -3732,9 +3712,6 @@ g_key_file_remove_group_node (GKeyFile *key_file,
key_file->groups = g_list_remove_link (key_file->groups, group_node);
- if (group->name != NULL)
- key_file->approximate_size -= strlen (group->name) + 3;
-
tmp = group->key_value_pairs;
while (tmp != NULL)
{
@@ -3811,7 +3788,6 @@ g_key_file_add_key_value_pair (GKeyFile *key_file,
g_hash_table_replace (group->lookup_map, pair->key, pair);
group->key_value_pairs = g_list_prepend (group->key_value_pairs, pair);
group->has_trailing_blank_line = FALSE;
- key_file->approximate_size += strlen (pair->key) + strlen (pair->value) + 2;
}
static void
@@ -3878,10 +3854,8 @@ g_key_file_remove_key (GKeyFile *key_file,
return FALSE;
}
- key_file->approximate_size -= strlen (pair->key) + strlen (pair->value) + 2;
-
group->key_value_pairs = g_list_remove (group->key_value_pairs, pair);
- g_hash_table_remove (group->lookup_map, pair->key);
+ g_hash_table_remove (group->lookup_map, pair->key);
g_key_file_key_value_pair_free (pair);
return TRUE;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]