#include <lttvwindow/toolbar.h>
#include <lttvwindow/lttvwindow.h>
#include <lttvwindow/lttvwindowtraces.h>
-
+#include <lttvwindow/lttv_plugin_tab.h>
static LttTime lttvwindow_default_time_width = { 1, 0 };
#define CLIP_BUF 256 // size of clipboard buffer
static char remember_plugins_dir[PATH_MAX] = "";
static char remember_trace_dir[PATH_MAX] = "";
+void tab_destructor(LttvPluginTab * ptab);
MainWindow * get_window_data_struct(GtkWidget * widget);
char * get_load_module(MainWindow *mw,
char * get_remove_trace(MainWindow *mw, char ** all_trace_name, int nb_trace);
char * get_selection(MainWindow *mw,
char ** all_name, int nb, char *title, char * column_title);
-Tab* create_tab(MainWindow * mw, Tab *copy_tab,
+void init_tab(Tab *tab, MainWindow * mw, Tab *copy_tab,
GtkNotebook * notebook, char * label);
static void insert_viewer(GtkWidget* widget, lttvwindow_viewer_constructor constructor);
-Tab *create_new_tab(GtkWidget* widget, gpointer user_data);
+LttvPluginTab *create_new_tab(GtkWidget* widget, gpointer user_data);
static gboolean lttvwindow_process_pending_requests(Tab *tab);
return 0;
}
+#if 0
+static void on_top_notify(GObject *gobject,
+ GParamSpec *arg1,
+ gpointer user_data)
+{
+ Tab *tab = (Tab*)user_data;
+ g_message("in on_top_notify.\n");
+}
+#endif //0
static gboolean viewer_grab_focus(GtkWidget *widget, GdkEventButton *event,
gpointer data)
{
TimeInterval * time_interval;
GtkWidget *page = gtk_notebook_get_nth_page(GTK_NOTEBOOK(notebook),
gtk_notebook_get_current_page(GTK_NOTEBOOK(notebook)));
+ LttvPluginTab *ptab;
Tab *tab;
if(!page) {
- tab = create_new_tab(widget, NULL);
+ ptab = create_new_tab(widget, NULL);
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
}
+ tab = ptab->tab;
viewer_container = tab->viewer_container;
- viewer = (GtkWidget*)constructor(tab);
+ viewer = (GtkWidget*)constructor(ptab);
if(viewer)
{
//gtk_multivpaned_widget_add(GTK_MULTIVPANED(multivpaned), viewer);
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
//gtk_multivpaned_widget_move_up(GTK_MULTIVPANED(tab->multivpaned));
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
//gtk_multivpaned_widget_move_down(GTK_MULTIVPANED(tab->multivpaned));
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
//gtk_multivpaned_widget_delete(GTK_MULTIVPANED(tab->multivpaned));
guint count;
LttvTracesetContextPosition *end_position;
+ if(lttvwindow_preempt_count > 0) return TRUE;
+
if(tab == NULL) {
g_critical("Foreground processing : tab does not exist. Processing removed.");
return FALSE;
GtkWidget *page = gtk_notebook_get_nth_page(GTK_NOTEBOOK(notebook),
gtk_notebook_get_current_page(GTK_NOTEBOOK(notebook)));
+ LttvPluginTab *ptab;
Tab *tab;
if(!page) {
- tab = create_new_tab(widget, NULL);
+ ptab = create_new_tab(widget, NULL);
+ tab = ptab->tab;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
//GtkDirSelection * file_selector = (GtkDirSelection *)gtk_dir_selection_new("Select a trace");
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
nb_trace =lttv_traceset_number(tab->traceset_info->traceset);
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
LttvHooks * tmp;
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
LttvHooks * tmp;
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
GSList *iter = tab->events_requests;
g_slist_remove_link(tab->events_requests, remove_iter);
}
tab->events_request_pending = FALSE;
+ tab->stop_foreground = TRUE;
g_idle_remove_by_data(tab);
g_assert(g_slist_length(tab->events_requests) == 0);
}
if(!page) {
return;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
if(size == 1) return;
/* create_new_tab calls create_tab to construct a new tab in the main window
*/
-Tab *create_new_tab(GtkWidget* widget, gpointer user_data){
+LttvPluginTab *create_new_tab(GtkWidget* widget, gpointer user_data)
+{
gchar label[PATH_MAX];
MainWindow * mw_data = get_window_data_struct(widget);
if(!page) {
copy_tab = NULL;
} else {
- copy_tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ copy_tab = ptab->tab;
}
strcpy(label,"Page");
- if(get_label(mw_data, label,"Get the name of the tab","Please input tab's name"))
- return (create_tab (mw_data, copy_tab, notebook, label));
- else
- return NULL;
+ if(get_label(mw_data, label,"Get the name of the tab","Please input tab's name")) {
+ LttvPluginTab *ptab;
+
+ ptab = g_object_new(LTTV_TYPE_PLUGIN_TAB, NULL);
+ init_tab (ptab->tab, mw_data, copy_tab, notebook, label);
+ ptab->parent.top_widget = ptab->tab->top_widget;
+ g_object_set_data_full(
+ G_OBJECT(ptab->tab->vbox),
+ "Tab_Plugin",
+ ptab,
+ (GDestroyNotify)tab_destructor);
+ return ptab;
+ }
+ else return NULL;
}
void
(double)end_time.tv_nsec);
/* width seconds */
- gtk_spin_button_set_range(GTK_SPIN_BUTTON(tab->MEntry7),
- (double)0,
- (double)upper.tv_sec);
+ if(time_width.tv_nsec == 0) {
+ gtk_spin_button_set_range(GTK_SPIN_BUTTON(tab->MEntry7),
+ (double)1,
+ (double)upper.tv_sec);
+ } else {
+ gtk_spin_button_set_range(GTK_SPIN_BUTTON(tab->MEntry7),
+ (double)0,
+ (double)upper.tv_sec);
+ }
gtk_spin_button_set_value(GTK_SPIN_BUTTON(tab->MEntry7),
(double)time_width.tv_sec);
if(!page) {
parent_tab = NULL;
} else {
- parent_tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ LttvPluginTab *ptab;
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ parent_tab = ptab->tab;
}
- new_tab = create_tab(new_m_window, parent_tab, notebook, "Traceset");
+ LttvPluginTab *ptab = g_object_new(LTTV_TYPE_PLUGIN_TAB, NULL);
+ init_tab(ptab->tab,
+ new_m_window, parent_tab, notebook, "Traceset");
+ ptab->parent.top_widget = ptab->tab->top_widget;
+ g_object_set_data_full(
+ G_OBJECT(ptab->tab->vbox),
+ "Tab_Plugin",
+ ptab,
+ (GDestroyNotify)tab_destructor);
+ new_tab = ptab->tab;
} else {
- new_tab = create_tab(new_m_window, NULL, notebook, "Traceset");
+ LttvPluginTab *ptab = g_object_new(LTTV_TYPE_PLUGIN_TAB, NULL);
+ init_tab(ptab->tab, new_m_window, NULL, notebook, "Traceset");
+ ptab->parent.top_widget = ptab->tab->top_widget;
+ g_object_set_data_full(
+ G_OBJECT(ptab->tab->vbox),
+ "Tab_Plugin",
+ ptab,
+ (GDestroyNotify)tab_destructor);
+ new_tab = ptab->tab;
}
/* Insert default viewers */
* destroy the tab
*/
-void tab_destructor(Tab * tab)
+void tab_destructor(LttvPluginTab * ptab)
{
int i, nb, ref_count;
LttvTrace * trace;
+ Tab *tab = ptab->tab;
gtk_object_destroy(GTK_OBJECT(tab->tooltips));
}
}
}
- lttv_filter_destroy(tab->filter);
lttv_traceset_destroy(tab->traceset_info->traceset);
/* Remove the idle events requests processing function of the tab */
g_idle_remove_by_data(tab);
g_slist_free(tab->events_requests);
g_free(tab->traceset_info);
- g_free(tab);
+ //g_free(tab);
+ g_object_unref(ptab);
}
/* Create a tab and insert it into the current main window
*/
-Tab* create_tab(MainWindow * mw, Tab *copy_tab,
+void init_tab(Tab *tab, MainWindow * mw, Tab *copy_tab,
GtkNotebook * notebook, char * label)
{
GList * list;
- Tab * tab;
+ //Tab * tab;
+ //LttvFilter *filter = NULL;
//create a new tab data structure
- tab = g_new(Tab,1);
+ //tab = g_new(Tab,1);
//construct and initialize the traceset_info
tab->traceset_info = g_new(TracesetInfo,1);
tab->interrupted_state = g_object_new(LTTV_ATTRIBUTE_TYPE, NULL);
tab->vbox = gtk_vbox_new(FALSE, 2);
+ tab->top_widget = tab->vbox;
+ //g_object_set_data_full(G_OBJECT(tab->top_widget), "filter",
+// filter, (GDestroyNotify)lttv_filter_destroy);
+
+// g_signal_connect (G_OBJECT(tab->top_widget),
+// "notify",
+// G_CALLBACK (on_top_notify),
+// (gpointer)tab);
+
tab->viewer_container = gtk_vbox_new(TRUE, 2);
tab->scrollbar = gtk_hscrollbar_new(NULL);
//tab->multivpaned = gtk_multi_vpaned_new();
gtk_box_pack_start (GTK_BOX (tab->MTimebar), tab->MText5a, FALSE, FALSE, 0);
temp_widget = gtk_vseparator_new();
gtk_widget_show(temp_widget);
+ gtk_box_pack_start (GTK_BOX (tab->MTimebar), temp_widget, FALSE, FALSE, 0);
gtk_box_pack_start (GTK_BOX (tab->MTimebar), tab->MEventBox8, FALSE,
FALSE, 0);
gtk_box_pack_start (GTK_BOX (tab->MTimebar), tab->MEntry7, FALSE, FALSE, 0);
/* Start with empty events requests list */
tab->events_requests = NULL;
tab->events_request_pending = FALSE;
+ tab->stop_foreground = FALSE;
+
- g_object_set_data_full(
- G_OBJECT(tab->vbox),
- "Tab_Info",
- tab,
- (GDestroyNotify)tab_destructor);
g_signal_connect(G_OBJECT(tab->scrollbar), "value-changed",
G_CALLBACK(scroll_value_changed_cb), tab);
LttvTraceset *traceset = tab->traceset_info->traceset;
SetTraceset(tab, traceset);
-
- return tab;
}
/*
}
-void create_main_window_with_trace(const gchar *path)
+void create_main_window_with_trace_list(GSList *traces)
{
- if(path == NULL) return;
+ GSList *iter = NULL;
/* Create window */
MainWindow *mw = construct_main_window(NULL);
GtkWidget * notebook = lookup_widget(widget, "MNotebook");
GtkWidget *page = gtk_notebook_get_nth_page(GTK_NOTEBOOK(notebook),
gtk_notebook_get_current_page(GTK_NOTEBOOK(notebook)));
+ LttvPluginTab *ptab;
Tab *tab;
if(!page) {
- tab = create_new_tab(widget, NULL);
+ ptab = create_new_tab(widget, NULL);
+ tab = ptab->tab;
} else {
- tab = (Tab *)g_object_get_data(G_OBJECT(page), "Tab_Info");
+ ptab = (LttvPluginTab *)g_object_get_data(G_OBJECT(page), "Tab_Plugin");
+ tab = ptab->tab;
}
- /* Add trace */
- gchar abs_path[PATH_MAX];
- LttvTrace *trace_v;
- LttTrace *trace;
-
- get_absolute_pathname(path, abs_path);
- trace_v = lttvwindowtraces_get_trace_by_name(abs_path);
- if(trace_v == NULL) {
- trace = ltt_trace_open(abs_path);
- if(trace == NULL) {
- g_warning("cannot open trace %s", abs_path);
-
- GtkWidget *dialogue =
- gtk_message_dialog_new(
- GTK_WINDOW(gtk_widget_get_toplevel(widget)),
- GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT,
- GTK_MESSAGE_ERROR,
- GTK_BUTTONS_OK,
- "Cannot open trace : maybe you should enter in the directory"
- "to select it ?");
- gtk_dialog_run(GTK_DIALOG(dialogue));
- gtk_widget_destroy(dialogue);
+ for(iter=traces; iter!=NULL; iter=g_slist_next(iter)) {
+ gchar *path = (gchar*)iter->data;
+ /* Add trace */
+ gchar abs_path[PATH_MAX];
+ LttvTrace *trace_v;
+ LttTrace *trace;
+
+ get_absolute_pathname(path, abs_path);
+ trace_v = lttvwindowtraces_get_trace_by_name(abs_path);
+ if(trace_v == NULL) {
+ trace = ltt_trace_open(abs_path);
+ if(trace == NULL) {
+ g_warning("cannot open trace %s", abs_path);
+
+ GtkWidget *dialogue =
+ gtk_message_dialog_new(
+ GTK_WINDOW(gtk_widget_get_toplevel(widget)),
+ GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT,
+ GTK_MESSAGE_ERROR,
+ GTK_BUTTONS_OK,
+ "Cannot open trace : maybe you should enter in the directory"
+ "to select it ?");
+ gtk_dialog_run(GTK_DIALOG(dialogue));
+ gtk_widget_destroy(dialogue);
+ } else {
+ trace_v = lttv_trace_new(trace);
+ lttvwindowtraces_add_trace(trace_v);
+ lttvwindow_add_trace(tab, trace_v);
+ }
} else {
- trace_v = lttv_trace_new(trace);
- lttvwindowtraces_add_trace(trace_v);
lttvwindow_add_trace(tab, trace_v);
}
- } else {
- lttvwindow_add_trace(tab, trace_v);
}
-
+
LttvTraceset *traceset;
traceset = tab->traceset_info->traceset;