#include "interface.h"
#include "support.h"
#include <lttvwindow/mainwindow.h>
+#include <lttvwindow/mainwindow-private.h>
#include "callbacks.h"
#include <ltt/trace.h>
LTTV_POINTER, &value));
g_assert((main_hooks = *(value.v_pointer)) != NULL);
- lttv_hooks_add(main_hooks, window_creation_hook, NULL);
+ lttv_hooks_add(main_hooks, window_creation_hook, NULL, LTTV_PRIO_DEFAULT);
}
-void
-main_window_free(MainWindow * mw)
-{
- if(mw){
- while(mw->tab){
- lttv_state_remove_event_hooks(
- (LttvTracesetState*)mw->tab->traceset_info->traceset_context);
- mw->tab = mw->tab->next;
- }
- g_object_unref(mw->attributes);
- g_main_window_list = g_slist_remove(g_main_window_list, mw);
-
- g_hash_table_destroy(mw->hash_menu_item);
- g_hash_table_destroy(mw->hash_toolbar_item);
-
- g_free(mw);
- mw = NULL;
- }
-}
-
void
main_window_destructor(MainWindow * mw)
{
- if(GTK_IS_WIDGET(mw->mwindow)){
- gtk_widget_destroy(mw->mwindow);
- // gtk_widget_destroy(mw->HelpContents);
- // gtk_widget_destroy(mw->AboutBox);
- mw = NULL;
- }
- //main_window_free called when the object mw in the widget is unref.
- //main_window_free(mw);
+ g_assert(GTK_IS_WIDGET(mw->mwindow));
+ gtk_widget_destroy(mw->mwindow);
}
-void main_window_destroy_walk(gpointer data, gpointer user_data)
-{
- main_window_destructor((MainWindow*)data);
-}
-
-
-
/**
* plugin's destroy function
*
LttvAttributeValue value;
LttvTrace *trace;
-
+ GSList *iter = NULL;
+
lttv_option_remove("trace");
lttv_hooks_remove_data(main_hooks, window_creation_hook, NULL);
g_debug("GUI destroy()");
if(g_main_window_list){
- g_slist_foreach(g_main_window_list, main_window_destroy_walk, NULL );
+ for(iter=g_main_window_list;iter!=NULL;iter=g_slist_next(iter)) {
+ main_window_destructor((MainWindow*)iter->data);
+ }
g_slist_free(g_main_window_list);
}
LTTV_MODULE("lttvwindow", "Viewer main window", \
"Viewer with multiple windows, tabs and panes for graphical modules", \
- init, destroy, "stats")
+ init, destroy, "stats", "option")