I'm reverting these so that menu generation doesn't crash anymore.

SVN revision: 26118
This commit is contained in:
David Walter Seikel 2006-09-24 21:21:24 +00:00
parent 59f86f0a78
commit 1f7e1dfa3a
4 changed files with 26 additions and 75 deletions

View File

@ -131,10 +131,8 @@ struct _Ecore_Desktop_Tree
{ {
Ecore_Desktop_Tree_Element *elements; /* An array of elements. */ Ecore_Desktop_Tree_Element *elements; /* An array of elements. */
int size; /* The size of the array. */ int size; /* The size of the array. */
#if 0
char **buffers; /* An array of pointers to the bits of data. */ char **buffers; /* An array of pointers to the bits of data. */
int buffers_size; /* The size of the array. */ int buffers_size; /* The size of the array. */
#endif
Ecore_Desktop_Tree *parent; /* Parent if this is a child. */ Ecore_Desktop_Tree *parent; /* Parent if this is a child. */
}; };
@ -247,8 +245,7 @@ extern "C"
Ecore_Desktop_Tree * Ecore_Desktop_Tree *
element); element);
Ecore_Desktop_Tree *ecore_desktop_tree_add_hash(Ecore_Desktop_Tree * tree, Ecore_Desktop_Tree *ecore_desktop_tree_add_hash(Ecore_Desktop_Tree * tree,
Ecore_Hash * element, Ecore_Hash * element);
int free);
void ecore_desktop_tree_remove(Ecore_Desktop_Tree * tree, void ecore_desktop_tree_remove(Ecore_Desktop_Tree * tree,
int element); int element);
int ecore_desktop_tree_exist(Ecore_Desktop_Tree * tree, int ecore_desktop_tree_exist(Ecore_Desktop_Tree * tree,

View File

@ -1,6 +1,3 @@
/*
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
*/
/* /*
* This conforms with the freedesktop.org Desktop Menu Specification version 0.92 * This conforms with the freedesktop.org Desktop Menu Specification version 0.92
* *
@ -150,7 +147,8 @@ ecore_desktop_menu_for_each(void (*func)
/* create the .desktop and order files from the menu */ /* create the .desktop and order files from the menu */
ecore_desktop_tree_foreach(menus, 0, _ecore_desktop_menu_make_apps, ecore_desktop_tree_foreach(menus, 0, _ecore_desktop_menu_make_apps,
func); func);
ecore_desktop_tree_del(menus); // FIXME: Can't free this just yet, causes major memory corruption.
// ecore_desktop_tree_del(menus);
} }
free(menu_file); free(menu_file);
} }
@ -269,8 +267,6 @@ _ecore_desktop_menu_get0(char *file, Ecore_Desktop_Tree * merge_stack,
if (oops == 0) if (oops == 0)
{ {
#if 1
/* FIXME: Somewhere in this code mem leaks. */
/* Get on with it. */ /* Get on with it. */
ecore_desktop_tree_foreach(menu_xml, 0, _ecore_desktop_menu_unxml, ecore_desktop_tree_foreach(menu_xml, 0, _ecore_desktop_menu_unxml,
&data); &data);
@ -304,7 +300,6 @@ _ecore_desktop_menu_get0(char *file, Ecore_Desktop_Tree * merge_stack,
printf("\n\n"); printf("\n\n");
#endif #endif
} }
#endif
} }
} }
else else
@ -313,14 +308,14 @@ _ecore_desktop_menu_get0(char *file, Ecore_Desktop_Tree * merge_stack,
if (oops) if (oops)
{ {
E_FN_DEL(ecore_desktop_tree_del, (menu_xml)); E_FN_DEL(ecore_desktop_tree_del, (menu_xml));
if (level == 0)
{
E_FN_DEL(ecore_desktop_tree_del, (merge_stack));
}
E_FREE(data.path);
E_FREE(data.base);
E_FN_DEL(ecore_desktop_tree_del, (data.stack));
} }
if (level == 0)
{
E_FN_DEL(ecore_desktop_tree_del, (merge_stack));
}
E_FN_DEL(ecore_desktop_tree_del, (data.stack));
E_FREE(data.path);
E_FREE(data.base);
return menu_xml; return menu_xml;
} }
@ -339,7 +334,6 @@ _ecore_desktop_menu_unxml(const void *data, Ecore_Desktop_Tree * tree,
tree->elements[element].type = tree->elements[element].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL; ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL;
tree->elements[element].element = NULL; tree->elements[element].element = NULL;
tree->elements[element].free = 0;
} }
else if (strcmp((char *)tree->elements[element].element, "<Menu") == 0) else if (strcmp((char *)tree->elements[element].element, "<Menu") == 0)
{ {
@ -355,11 +349,9 @@ _ecore_desktop_menu_unxml(const void *data, Ecore_Desktop_Tree * tree,
flags = (char *)menu->elements[0].element; flags = (char *)menu->elements[0].element;
flags += 7; flags += 7;
/* FIXME: Should this be here? It is done again at the end */
tree->elements[element].element = menu; tree->elements[element].element = menu;
tree->elements[element].type = tree->elements[element].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE; ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE;
tree->elements[element].free = 1;
for (i = element + 1; i < tree->size; i++) for (i = element + 1; i < tree->size; i++)
{ {
int result = 0; int result = 0;
@ -374,7 +366,6 @@ _ecore_desktop_menu_unxml(const void *data, Ecore_Desktop_Tree * tree,
tree->elements[i].type = tree->elements[i].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL; ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL;
tree->elements[i].element = NULL; tree->elements[i].element = NULL;
tree->elements[i].free = 0;
} }
else else
if (strcmp if (strcmp
@ -612,7 +603,6 @@ _ecore_desktop_menu_unxml(const void *data, Ecore_Desktop_Tree * tree,
tree->elements[element].element = menu; tree->elements[element].element = menu;
tree->elements[element].type = tree->elements[element].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE; ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE;
tree->elements[element].free = 1;
} }
} }
} }
@ -638,9 +628,9 @@ _ecore_desktop_menu_create_menu()
ecore_hash_set_free_value(apps, free); ecore_hash_set_free_value(apps, free);
ecore_desktop_tree_extend(menu, "<MENU < > <> <>"); ecore_desktop_tree_extend(menu, "<MENU < > <> <>");
ecore_desktop_tree_extend(menu, "<MENU_PATH "); ecore_desktop_tree_extend(menu, "<MENU_PATH ");
ecore_desktop_tree_add_hash(menu, pool, 1); ecore_desktop_tree_add_hash(menu, pool);
ecore_desktop_tree_add_child(menu, rules); ecore_desktop_tree_add_child(menu, rules);
ecore_desktop_tree_add_hash(menu, apps, 1); ecore_desktop_tree_add_hash(menu, apps);
} }
else else
{ {
@ -1474,9 +1464,9 @@ _ecore_desktop_menu_generate(const void *data, Ecore_Desktop_Tree * tree,
{ {
while (unxml_data->stack->size < level) while (unxml_data->stack->size < level)
ecore_desktop_tree_add_hash(unxml_data->stack, ecore_desktop_tree_add_hash(unxml_data->stack,
generate_data.pool, 0); generate_data.pool);
ecore_desktop_tree_add_hash(unxml_data->stack, ecore_desktop_tree_add_hash(unxml_data->stack,
generate_data.pool, 0); generate_data.pool);
} }
else else
{ {
@ -1484,7 +1474,6 @@ _ecore_desktop_menu_generate(const void *data, Ecore_Desktop_Tree * tree,
ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH; ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH;
unxml_data->stack->elements[level].element = unxml_data->stack->elements[level].element =
generate_data.pool; generate_data.pool;
unxml_data->stack->elements[level].free = 0;
} }
for (i = level - 1; i >= 0; i--) for (i = level - 1; i >= 0; i--)
{ {
@ -1594,7 +1583,7 @@ _ecore_desktop_menu_select_app(void *value, void *user_data)
desktop->allocated = TRUE; desktop->allocated = TRUE;
if (generate_data->include) if (generate_data->include)
{ {
ecore_hash_set(generate_data->apps, strdup(key), strdup(app)); ecore_hash_set(generate_data->apps, key, strdup(app));
#ifdef DEBUG #ifdef DEBUG
printf("INCLUDING %s%s - %s\n", printf("INCLUDING %s%s - %s\n",
((generate_data->unallocated) ? "UNALLOCATED " : ""), ((generate_data->unallocated) ? "UNALLOCATED " : ""),

View File

@ -1,6 +1,3 @@
/*
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
*/
#include <sys/types.h> #include <sys/types.h>
#include "Ecore_Desktop.h" #include "Ecore_Desktop.h"
@ -45,12 +42,10 @@ ecore_desktop_tree_new(char *buffer)
tree = E_NEW(Ecore_Desktop_Tree, 1); tree = E_NEW(Ecore_Desktop_Tree, 1);
if ((tree) && (buffer)) if ((tree) && (buffer))
{ {
#if 0
tree->buffers = tree->buffers =
(char **)realloc(tree->buffers, (char **)realloc(tree->buffers,
(tree->buffers_size + 1) * sizeof(char *)); (tree->buffers_size + 1) * sizeof(char *));
tree->buffers[tree->buffers_size++] = strdup(buffer); tree->buffers[tree->buffers_size++] = strdup(buffer);
#endif
} }
return tree; return tree;
} }
@ -64,8 +59,7 @@ ecore_desktop_tree_add(Ecore_Desktop_Tree * tree, char *element)
1) * 1) *
sizeof sizeof
(Ecore_Desktop_Tree_Element)); (Ecore_Desktop_Tree_Element));
tree->elements[tree->size].element = strdup(element); tree->elements[tree->size].element = element;
tree->elements[tree->size].free = 1;
tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_STRING; tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_STRING;
return tree; return tree;
} }
@ -73,14 +67,11 @@ ecore_desktop_tree_add(Ecore_Desktop_Tree * tree, char *element)
Ecore_Desktop_Tree * Ecore_Desktop_Tree *
ecore_desktop_tree_extend(Ecore_Desktop_Tree * tree, char *element) ecore_desktop_tree_extend(Ecore_Desktop_Tree * tree, char *element)
{ {
#if 0
tree->buffers = tree->buffers =
(char **)realloc(tree->buffers, (char **)realloc(tree->buffers,
(tree->buffers_size + 1) * sizeof(char *)); (tree->buffers_size + 1) * sizeof(char *));
tree->buffers[tree->buffers_size++] = strdup(element); tree->buffers[tree->buffers_size++] = strdup(element);
tree = ecore_desktop_tree_add(tree, tree->buffers[tree->buffers_size - 1]); tree = ecore_desktop_tree_add(tree, tree->buffers[tree->buffers_size - 1]);
#endif
tree = ecore_desktop_tree_add(tree, element);
return tree; return tree;
} }
@ -88,17 +79,13 @@ ecore_desktop_tree_extend(Ecore_Desktop_Tree * tree, char *element)
void void
ecore_desktop_tree_track(Ecore_Desktop_Tree * tree, void *element) ecore_desktop_tree_track(Ecore_Desktop_Tree * tree, void *element)
{ {
#if 0
tree->buffers = tree->buffers =
(char **)realloc(tree->buffers, (char **)realloc(tree->buffers,
(tree->buffers_size + 1) * sizeof(char *)); (tree->buffers_size + 1) * sizeof(char *));
tree->buffers[tree->buffers_size++] = element; tree->buffers[tree->buffers_size++] = element;
#endif
} }
/* OK, so we need an insert after all, and it falls into the dumb category. */ /* OK, so we need an insert after all, and it falls into the dumb category. */
/* FIXME: Needs to handle .free */
#if 0
Ecore_Desktop_Tree * Ecore_Desktop_Tree *
ecore_desktop_tree_insert(Ecore_Desktop_Tree * tree, int before, void *element, ecore_desktop_tree_insert(Ecore_Desktop_Tree * tree, int before, void *element,
Ecore_Desktop_Tree_Element_Type type) Ecore_Desktop_Tree_Element_Type type)
@ -116,14 +103,11 @@ ecore_desktop_tree_insert(Ecore_Desktop_Tree * tree, int before, void *element,
{ {
tree->elements[i].element = tree->elements[i - 1].element; tree->elements[i].element = tree->elements[i - 1].element;
tree->elements[i].type = tree->elements[i - 1].type; tree->elements[i].type = tree->elements[i - 1].type;
tree->elements[i].free = tree->elements[i - 1].free;
} }
tree->elements[before].element = element; tree->elements[before].element = element;
tree->elements[before].type = type; tree->elements[before].type = type;
tree->elements[before].free = free;
return tree; return tree;
} }
#endif
/* OK, so we need a tree merge after all, and it falls into the dumb category. */ /* OK, so we need a tree merge after all, and it falls into the dumb category. */
Ecore_Desktop_Tree * Ecore_Desktop_Tree *
@ -146,18 +130,15 @@ ecore_desktop_tree_merge(Ecore_Desktop_Tree * tree, int before,
{ {
tree->elements[i].element = tree->elements[i - size].element; tree->elements[i].element = tree->elements[i - size].element;
tree->elements[i].type = tree->elements[i - size].type; tree->elements[i].type = tree->elements[i - size].type;
tree->elements[i].free = tree->elements[i - size].free;
} }
for (i = 0; i < size; i++) for (i = 0; i < size; i++)
{ {
tree->elements[before + i].element = element->elements[i].element; tree->elements[before + i].element = element->elements[i].element;
tree->elements[before + i].type = element->elements[i].type; tree->elements[before + i].type = element->elements[i].type;
tree->elements[before + i].free = element->elements[i].free;
} }
} }
/* Careful, this might screw up the freeing order if that is important. */ /* Careful, this might screw up the freeing order if that is important. */
#if 0
size = element->buffers_size; size = element->buffers_size;
if (size) if (size)
{ {
@ -171,7 +152,6 @@ ecore_desktop_tree_merge(Ecore_Desktop_Tree * tree, int before,
} }
*/ */
} }
#endif
return tree; return tree;
} }
@ -186,14 +166,13 @@ ecore_desktop_tree_add_child(Ecore_Desktop_Tree * tree,
sizeof sizeof
(Ecore_Desktop_Tree_Element)); (Ecore_Desktop_Tree_Element));
tree->elements[tree->size].element = element; tree->elements[tree->size].element = element;
tree->elements[tree->size].free = 1;
tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE; tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE;
element->parent = tree; element->parent = tree;
return tree; return tree;
} }
Ecore_Desktop_Tree * Ecore_Desktop_Tree *
ecore_desktop_tree_add_hash(Ecore_Desktop_Tree * tree, Ecore_Hash * element, int free) ecore_desktop_tree_add_hash(Ecore_Desktop_Tree * tree, Ecore_Hash * element)
{ {
tree->elements = tree->elements =
(Ecore_Desktop_Tree_Element *) realloc(tree->elements, (Ecore_Desktop_Tree_Element *) realloc(tree->elements,
@ -202,8 +181,6 @@ ecore_desktop_tree_add_hash(Ecore_Desktop_Tree * tree, Ecore_Hash * element, int
sizeof sizeof
(Ecore_Desktop_Tree_Element)); (Ecore_Desktop_Tree_Element));
tree->elements[tree->size].element = element; tree->elements[tree->size].element = element;
if (free) tree->elements[tree->size].free = 1;
else tree->elements[tree->size].free = 0;
tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH; tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH;
return tree; return tree;
} }
@ -215,7 +192,6 @@ ecore_desktop_tree_remove(Ecore_Desktop_Tree * tree, int element)
{ {
tree->elements[element].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL; tree->elements[element].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL;
tree->elements[element].element = NULL; tree->elements[element].element = NULL;
tree->elements[element].free = 0;
} }
} }
@ -276,10 +252,8 @@ ecore_desktop_tree_foreach(Ecore_Desktop_Tree * tree, int level,
moved = 1; moved = 1;
tree->elements[k].type = tree->elements[j].type; tree->elements[k].type = tree->elements[j].type;
tree->elements[k].element = tree->elements[j].element; tree->elements[k].element = tree->elements[j].element;
tree->elements[k].free = tree->elements[j].free;
tree->elements[j].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL; tree->elements[j].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL;
tree->elements[j].element = NULL; tree->elements[j].element = NULL;
tree->elements[j].free = 0;
j++; j++;
k++; k++;
} }
@ -373,22 +347,16 @@ ecore_desktop_tree_del(Ecore_Desktop_Tree * tree)
for (i = tree->size - 1; i >= 0; i--) for (i = tree->size - 1; i >= 0; i--)
{ {
if (tree->elements[i].free) if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE)
{ ecore_desktop_tree_del((Ecore_Desktop_Tree *) tree->elements[i].
if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_STRING) element);
free(tree->elements[i].element); else if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH)
else if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE) ecore_hash_destroy((Ecore_Hash *) tree->elements[i].element);
ecore_desktop_tree_del((Ecore_Desktop_Tree *) tree->elements[i].element);
else if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH)
ecore_hash_destroy((Ecore_Hash *) tree->elements[i].element);
}
} }
E_FREE(tree->elements); E_FREE(tree->elements);
#if 0
for (i = tree->buffers_size - 1; i >= 0; i--) for (i = tree->buffers_size - 1; i >= 0; i--)
E_FREE(tree->buffers[i]); E_FREE(tree->buffers[i]);
#endif
E_FREE(tree); E_FREE(tree);
} }

View File

@ -1,6 +1,3 @@
/*
* vim:ts=8:sw=3:sts=8:noexpandtab:cino=>5n-3f0^-2{2
*/
#include "Ecore_Desktop.h" #include "Ecore_Desktop.h"
#include "ecore_desktop_private.h" #include "ecore_desktop_private.h"
@ -64,7 +61,6 @@ ecore_desktop_xmlame_get(char *file)
ecore_desktop_tree_extend(tree, file); ecore_desktop_tree_extend(tree, file);
_ecore_desktop_xmlame_parse(tree, buffer); _ecore_desktop_xmlame_parse(tree, buffer);
} }
free(buffer);
} }
return tree; return tree;
} }
@ -72,7 +68,7 @@ ecore_desktop_xmlame_get(char *file)
static char * static char *
_ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer) _ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
{ {
while (*buffer != '\0') do
{ {
char *text; char *text;
@ -90,7 +86,7 @@ _ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
t = *buffer; t = *buffer;
*buffer = '\0'; *buffer = '\0';
ecore_desktop_tree_extend(tree, text); ecore_desktop_tree_extend(tree, strdup(text));
*buffer = t; *buffer = t;
} }
if (*buffer != '\0') if (*buffer != '\0')
@ -119,7 +115,7 @@ _ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
{ /* The beginning of an element. */ { /* The beginning of an element. */
Ecore_Desktop_Tree *new_tree; Ecore_Desktop_Tree *new_tree;
new_tree = ecore_desktop_tree_new(NULL); new_tree = ecore_desktop_xmlame_new(NULL);
if (new_tree) if (new_tree)
{ {
ecore_desktop_tree_add_child(tree, new_tree); ecore_desktop_tree_add_child(tree, new_tree);
@ -131,6 +127,7 @@ _ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
} }
} }
} }
while (*buffer != '\0');
return buffer; return buffer;
} }