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. */
int size; /* The size of the array. */
#if 0
char **buffers; /* An array of pointers to the bits of data. */
int buffers_size; /* The size of the array. */
#endif
Ecore_Desktop_Tree *parent; /* Parent if this is a child. */
};
@ -247,8 +245,7 @@ extern "C"
Ecore_Desktop_Tree *
element);
Ecore_Desktop_Tree *ecore_desktop_tree_add_hash(Ecore_Desktop_Tree * tree,
Ecore_Hash * element,
int free);
Ecore_Hash * element);
void ecore_desktop_tree_remove(Ecore_Desktop_Tree * tree,
int element);
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
*
@ -150,7 +147,8 @@ ecore_desktop_menu_for_each(void (*func)
/* create the .desktop and order files from the menu */
ecore_desktop_tree_foreach(menus, 0, _ecore_desktop_menu_make_apps,
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);
}
@ -269,8 +267,6 @@ _ecore_desktop_menu_get0(char *file, Ecore_Desktop_Tree * merge_stack,
if (oops == 0)
{
#if 1
/* FIXME: Somewhere in this code mem leaks. */
/* Get on with it. */
ecore_desktop_tree_foreach(menu_xml, 0, _ecore_desktop_menu_unxml,
&data);
@ -304,7 +300,6 @@ _ecore_desktop_menu_get0(char *file, Ecore_Desktop_Tree * merge_stack,
printf("\n\n");
#endif
}
#endif
}
}
else
@ -313,14 +308,14 @@ _ecore_desktop_menu_get0(char *file, Ecore_Desktop_Tree * merge_stack,
if (oops)
{
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;
}
@ -339,7 +334,6 @@ _ecore_desktop_menu_unxml(const void *data, Ecore_Desktop_Tree * tree,
tree->elements[element].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL;
tree->elements[element].element = NULL;
tree->elements[element].free = 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 += 7;
/* FIXME: Should this be here? It is done again at the end */
tree->elements[element].element = menu;
tree->elements[element].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE;
tree->elements[element].free = 1;
for (i = element + 1; i < tree->size; i++)
{
int result = 0;
@ -374,7 +366,6 @@ _ecore_desktop_menu_unxml(const void *data, Ecore_Desktop_Tree * tree,
tree->elements[i].type =
ECORE_DESKTOP_TREE_ELEMENT_TYPE_NULL;
tree->elements[i].element = NULL;
tree->elements[i].free = 0;
}
else
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].type =
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_desktop_tree_extend(menu, "<MENU < > <> <>");
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_hash(menu, apps, 1);
ecore_desktop_tree_add_hash(menu, apps);
}
else
{
@ -1474,9 +1464,9 @@ _ecore_desktop_menu_generate(const void *data, Ecore_Desktop_Tree * tree,
{
while (unxml_data->stack->size < level)
ecore_desktop_tree_add_hash(unxml_data->stack,
generate_data.pool, 0);
generate_data.pool);
ecore_desktop_tree_add_hash(unxml_data->stack,
generate_data.pool, 0);
generate_data.pool);
}
else
{
@ -1484,7 +1474,6 @@ _ecore_desktop_menu_generate(const void *data, Ecore_Desktop_Tree * tree,
ECORE_DESKTOP_TREE_ELEMENT_TYPE_HASH;
unxml_data->stack->elements[level].element =
generate_data.pool;
unxml_data->stack->elements[level].free = 0;
}
for (i = level - 1; i >= 0; i--)
{
@ -1594,7 +1583,7 @@ _ecore_desktop_menu_select_app(void *value, void *user_data)
desktop->allocated = TRUE;
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
printf("INCLUDING %s%s - %s\n",
((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 "Ecore_Desktop.h"
@ -45,12 +42,10 @@ ecore_desktop_tree_new(char *buffer)
tree = E_NEW(Ecore_Desktop_Tree, 1);
if ((tree) && (buffer))
{
#if 0
tree->buffers =
(char **)realloc(tree->buffers,
(tree->buffers_size + 1) * sizeof(char *));
tree->buffers[tree->buffers_size++] = strdup(buffer);
#endif
}
return tree;
}
@ -64,8 +59,7 @@ ecore_desktop_tree_add(Ecore_Desktop_Tree * tree, char *element)
1) *
sizeof
(Ecore_Desktop_Tree_Element));
tree->elements[tree->size].element = strdup(element);
tree->elements[tree->size].free = 1;
tree->elements[tree->size].element = element;
tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_STRING;
return tree;
}
@ -73,14 +67,11 @@ ecore_desktop_tree_add(Ecore_Desktop_Tree * tree, char *element)
Ecore_Desktop_Tree *
ecore_desktop_tree_extend(Ecore_Desktop_Tree * tree, char *element)
{
#if 0
tree->buffers =
(char **)realloc(tree->buffers,
(tree->buffers_size + 1) * sizeof(char *));
tree->buffers[tree->buffers_size++] = strdup(element);
tree = ecore_desktop_tree_add(tree, tree->buffers[tree->buffers_size - 1]);
#endif
tree = ecore_desktop_tree_add(tree, element);
return tree;
}
@ -88,17 +79,13 @@ ecore_desktop_tree_extend(Ecore_Desktop_Tree * tree, char *element)
void
ecore_desktop_tree_track(Ecore_Desktop_Tree * tree, void *element)
{
#if 0
tree->buffers =
(char **)realloc(tree->buffers,
(tree->buffers_size + 1) * sizeof(char *));
tree->buffers[tree->buffers_size++] = element;
#endif
}
/* 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_insert(Ecore_Desktop_Tree * tree, int before, void *element,
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].type = tree->elements[i - 1].type;
tree->elements[i].free = tree->elements[i - 1].free;
}
tree->elements[before].element = element;
tree->elements[before].type = type;
tree->elements[before].free = free;
return tree;
}
#endif
/* OK, so we need a tree merge after all, and it falls into the dumb category. */
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].type = tree->elements[i - size].type;
tree->elements[i].free = tree->elements[i - size].free;
}
for (i = 0; i < size; i++)
{
tree->elements[before + i].element = element->elements[i].element;
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. */
#if 0
size = element->buffers_size;
if (size)
{
@ -171,7 +152,6 @@ ecore_desktop_tree_merge(Ecore_Desktop_Tree * tree, int before,
}
*/
}
#endif
return tree;
}
@ -186,14 +166,13 @@ ecore_desktop_tree_add_child(Ecore_Desktop_Tree * tree,
sizeof
(Ecore_Desktop_Tree_Element));
tree->elements[tree->size].element = element;
tree->elements[tree->size].free = 1;
tree->elements[tree->size++].type = ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE;
element->parent = tree;
return 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 =
(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
(Ecore_Desktop_Tree_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;
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].element = NULL;
tree->elements[element].free = 0;
}
}
@ -276,10 +252,8 @@ ecore_desktop_tree_foreach(Ecore_Desktop_Tree * tree, int level,
moved = 1;
tree->elements[k].type = tree->elements[j].type;
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].element = NULL;
tree->elements[j].free = 0;
j++;
k++;
}
@ -373,22 +347,16 @@ ecore_desktop_tree_del(Ecore_Desktop_Tree * tree)
for (i = tree->size - 1; i >= 0; i--)
{
if (tree->elements[i].free)
{
if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_STRING)
free(tree->elements[i].element);
else if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE)
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);
}
if (tree->elements[i].type == ECORE_DESKTOP_TREE_ELEMENT_TYPE_TREE)
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);
#if 0
for (i = tree->buffers_size - 1; i >= 0; i--)
E_FREE(tree->buffers[i]);
#endif
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_private.h"
@ -64,7 +61,6 @@ ecore_desktop_xmlame_get(char *file)
ecore_desktop_tree_extend(tree, file);
_ecore_desktop_xmlame_parse(tree, buffer);
}
free(buffer);
}
return tree;
}
@ -72,7 +68,7 @@ ecore_desktop_xmlame_get(char *file)
static char *
_ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
{
while (*buffer != '\0')
do
{
char *text;
@ -90,7 +86,7 @@ _ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
t = *buffer;
*buffer = '\0';
ecore_desktop_tree_extend(tree, text);
ecore_desktop_tree_extend(tree, strdup(text));
*buffer = t;
}
if (*buffer != '\0')
@ -119,7 +115,7 @@ _ecore_desktop_xmlame_parse(Ecore_Desktop_Tree * tree, char *buffer)
{ /* The beginning of an element. */
Ecore_Desktop_Tree *new_tree;
new_tree = ecore_desktop_tree_new(NULL);
new_tree = ecore_desktop_xmlame_new(NULL);
if (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;
}