X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=ltt%2Fbranches%2Fpoly%2Flttv%2Fmodules%2Fgui%2FmainWin%2Fsrc%2Fcallbacks.c;h=df9aa693072b9109ac23c9ec84b8c6e2ed1cf2b6;hb=49bf71b500f112cc90b790eb3975cceac351d021;hp=ca532d25d57bb7f96570b6b21162b02b69d4ffbb;hpb=1f1ae8291146c371158191d7c7efd426e4a6f1ce;p=lttv.git diff --git a/ltt/branches/poly/lttv/modules/gui/mainWin/src/callbacks.c b/ltt/branches/poly/lttv/modules/gui/mainWin/src/callbacks.c index ca532d25..df9aa693 100644 --- a/ltt/branches/poly/lttv/modules/gui/mainWin/src/callbacks.c +++ b/ltt/branches/poly/lttv/modules/gui/mainWin/src/callbacks.c @@ -15,11 +15,12 @@ #include #include #include +#include #define PATH_LENGTH 256 #define DEFAULT_TIME_WIDTH_S 1 -extern LttTrace *g_init_trace ; +extern LttvTrace *g_init_trace ; /** Array containing instanced objects. */ @@ -31,9 +32,27 @@ MainWindow * get_window_data_struct(GtkWidget * widget); char * get_unload_module(char ** loaded_module_name, int nb_module); char * get_remove_trace(char ** all_trace_name, int nb_trace); char * get_selection(char ** all_name, int nb, char *title, char * column_title); -void * create_tab(GtkWidget* parent, GtkNotebook * notebook, char * label); +void get_filter_selection(LttvTracesetSelector *s, char *title, char * column_title); +void * create_tab(MainWindow * parent, MainWindow * current_window, + GtkNotebook * notebook, char * label); void insert_viewer(GtkWidget* widget, view_constructor constructor); +void update_filter(LttvTracesetSelector *s, GtkTreeStore *store ); + +void checkbox_changed(GtkTreeView *treeview, + GtkTreePath *arg1, + GtkTreeViewColumn *arg2, + gpointer user_data); +void remove_trace_from_traceset_selector(GtkMultiVPaned * paned, unsigned i); +void add_trace_into_traceset_selector(GtkMultiVPaned * paned, LttTrace * trace); + +LttvTracesetSelector * construct_traceset_selector(LttvTraceset * traceset); + +enum { + CHECKBOX_COLUMN, + NAME_COLUMN, + TOTAL_COLUMNS +}; enum { @@ -42,30 +61,81 @@ enum }; +LttvTracesetSelector * construct_traceset_selector(LttvTraceset * traceset) +{ + LttvTracesetSelector * s; + LttvTraceSelector * trace; + LttvTracefileSelector * tracefile; + int i, j, nb_trace, nb_tracefile, nb_control, nb_per_cpu; + LttvTrace * trace_v; + LttTrace * t; + LttTracefile *tf; + + s = lttv_traceset_selector_new(lttv_traceset_name(traceset)); + nb_trace = lttv_traceset_number(traceset); + for(i=0;icurrent_tab) return; - custom = mw_data->current_tab->custom; + multi_vpaned = mw_data->current_tab->multi_vpaned; - viewer = (GtkWidget*)constructor(mw_data); + s = construct_traceset_selector(mw_data->current_tab->traceset_info->traceset); + viewer = (GtkWidget*)constructor(mw_data, s, "Traceset_Selector"); if(viewer) { - gtk_custom_widget_add(custom, viewer); + gtk_multi_vpaned_widget_add(multi_vpaned, viewer); // Added by MD // g_object_unref(G_OBJECT(viewer)); } @@ -78,7 +148,7 @@ void get_label_string (GtkWidget * text, gchar * label) strcpy(label,gtk_entry_get_text(entry)); } -void get_label(GtkWindow * mw, gchar * str, gchar* dialogue_title, gchar * label_str) +void get_label(MainWindow * mw, gchar * str, gchar* dialogue_title, gchar * label_str) { GtkWidget * dialogue; GtkWidget * text; @@ -138,10 +208,10 @@ void create_new_window(GtkWidget* widget, gpointer user_data, gboolean clone) if(clone){ g_printf("Clone : use the same traceset\n"); - construct_main_window(parent, NULL, FALSE); + construct_main_window(parent, NULL); }else{ g_printf("Empty : traceset is set to NULL\n"); - construct_main_window(NULL, parent->win_creation_data, FALSE); + construct_main_window(NULL, parent->win_creation_data); } } @@ -149,21 +219,21 @@ void move_up_viewer(GtkWidget * widget, gpointer user_data) { MainWindow * mw = get_window_data_struct(widget); if(!mw->current_tab) return; - gtk_custom_widget_move_up(mw->current_tab->custom); + gtk_multi_vpaned_widget_move_up(mw->current_tab->multi_vpaned); } void move_down_viewer(GtkWidget * widget, gpointer user_data) { MainWindow * mw = get_window_data_struct(widget); if(!mw->current_tab) return; - gtk_custom_widget_move_down(mw->current_tab->custom); + gtk_multi_vpaned_widget_move_down(mw->current_tab->multi_vpaned); } void delete_viewer(GtkWidget * widget, gpointer user_data) { MainWindow * mw = get_window_data_struct(widget); if(!mw->current_tab) return; - gtk_custom_widget_delete(mw->current_tab->custom); + gtk_multi_vpaned_widget_delete(mw->current_tab->multi_vpaned); } void open_traceset(GtkWidget * widget, gpointer user_data) @@ -195,6 +265,38 @@ void open_traceset(GtkWidget * widget, gpointer user_data) } +void add_trace_into_traceset_selector(GtkMultiVPaned * paned, LttTrace * t) +{ + int j, nb_tracefile, nb_control, nb_per_cpu; + LttvTracesetSelector * s; + LttvTraceSelector * trace; + LttvTracefileSelector * tracefile; + LttTracefile * tf; + GtkWidget * w; + + w = gtk_multi_vpaned_get_first_widget(paned); + while(w){ + s = g_object_get_data(G_OBJECT(w), "Traceset_Selector"); + + trace = lttv_trace_selector_new(t); + lttv_traceset_selector_add(s, trace); + nb_control = ltt_trace_control_tracefile_number(t); + nb_per_cpu = ltt_trace_per_cpu_tracefile_number(t); + nb_tracefile = nb_control + nb_per_cpu; + + for(j = 0 ; j < nb_tracefile ; j++) { + if(j < nb_control) + tf = ltt_trace_control_tracefile_get(t, j); + else + tf = ltt_trace_per_cpu_tracefile_get(t, j - nb_control); + tracefile = lttv_tracefile_selector_new(tf); + lttv_trace_selector_add(trace, tracefile); + } + + w = gtk_multi_vpaned_get_next_widget(paned); + } +} + void add_trace(GtkWidget * widget, gpointer user_data) { LttTrace *trace; @@ -214,24 +316,47 @@ void add_trace(GtkWidget * widget, gpointer user_data) trace = ltt_trace_open(dir); if(trace == NULL) g_critical("cannot open trace %s", dir); trace_v = lttv_trace_new(trace); - traceset = mw_data->traceset_info->traceset; - if(mw_data->traceset_info->traceset_context != NULL){ - lttv_context_fini(LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context)); - g_object_unref(mw_data->traceset_info->traceset_context); + traceset = mw_data->current_tab->traceset_info->traceset; + if(mw_data->current_tab->traceset_info->traceset_context != NULL){ + lttv_context_fini(LTTV_TRACESET_CONTEXT(mw_data->current_tab-> + traceset_info->traceset_context)); + g_object_unref(mw_data->current_tab->traceset_info->traceset_context); } lttv_traceset_add(traceset, trace_v); - mw_data->traceset_info->traceset_context = + mw_data->current_tab->traceset_info->traceset_context = g_object_new(LTTV_TRACESET_STATS_TYPE, NULL); lttv_context_init( - LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context),traceset); + LTTV_TRACESET_CONTEXT(mw_data->current_tab->traceset_info-> + traceset_context),traceset); + add_trace_into_traceset_selector(mw_data->current_tab->multi_vpaned, trace); + + gtk_widget_destroy((GtkWidget*)file_selector); + + //update current tab + // set_current_time(mw_data, &(mw_data->current_tab->current_time)); + break; case GTK_RESPONSE_REJECT: case GTK_RESPONSE_CANCEL: default: gtk_widget_destroy((GtkWidget*)file_selector); break; } +} - g_printf("add a trace to a trace set\n"); +void remove_trace_from_traceset_selector(GtkMultiVPaned * paned, unsigned i) +{ + LttvTracesetSelector * s; + LttvTraceSelector * t; + GtkWidget * w; + + w = gtk_multi_vpaned_get_first_widget(paned); + while(w){ + s = g_object_get_data(G_OBJECT(w), "Traceset_Selector"); + t = lttv_traceset_selector_get(s,i); + lttv_traceset_selector_remove(s, i); + lttv_trace_selector_destroy(t); + w = gtk_multi_vpaned_get_next_widget(paned); + } } void remove_trace(GtkWidget * widget, gpointer user_data) @@ -242,11 +367,16 @@ void remove_trace(GtkWidget * widget, gpointer user_data) gint i, nb_trace; char ** name, *remove_trace_name; MainWindow * mw_data = get_window_data_struct(widget); + LttvTracesetSelector * s; + LttvTraceSelector * t; + GtkWidget * w; + gboolean selected; - nb_trace =lttv_traceset_number(mw_data->traceset_info->traceset); + nb_trace =lttv_traceset_number(mw_data->current_tab->traceset_info->traceset); name = g_new(char*,nb_trace); for(i = 0; i < nb_trace; i++){ - trace_v = lttv_traceset_get(mw_data->traceset_info->traceset, i); + trace_v = lttv_traceset_get(mw_data->current_tab-> + traceset_info->traceset, i); trace = lttv_trace(trace_v); name[i] = trace->pathname; } @@ -256,23 +386,52 @@ void remove_trace(GtkWidget * widget, gpointer user_data) if(remove_trace_name){ for(i=0; itraceset_info->traceset; - if(mw_data->traceset_info->traceset_context != NULL){ - lttv_context_fini(LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context)); - g_object_unref(mw_data->traceset_info->traceset_context); + //unselect the trace from the current viewer + w = gtk_multi_vpaned_get_widget(mw_data->current_tab->multi_vpaned); + s = g_object_get_data(G_OBJECT(w), "Traceset_Selector"); + t = lttv_traceset_selector_get(s,i); + lttv_trace_selector_set_selected(t, FALSE); + + //check if other viewers select the trace + w = gtk_multi_vpaned_get_first_widget(mw_data->current_tab->multi_vpaned); + while(w){ + s = g_object_get_data(G_OBJECT(w), "Traceset_Selector"); + t = lttv_traceset_selector_get(s,i); + selected = lttv_trace_selector_get_selected(t); + if(selected)break; + w = gtk_multi_vpaned_get_next_widget(mw_data->current_tab->multi_vpaned); + } + + //if no viewer selects the trace, remove it + if(!selected){ + remove_trace_from_traceset_selector(mw_data->current_tab->multi_vpaned, i); + + traceset = mw_data->current_tab->traceset_info->traceset; + trace_v = lttv_traceset_get(traceset, i); + if(lttv_trace_get_ref_number(trace_v) <= 1) + ltt_trace_close(lttv_trace(trace_v)); + + if(mw_data->current_tab->traceset_info->traceset_context != NULL){ + lttv_context_fini(LTTV_TRACESET_CONTEXT(mw_data->current_tab-> + traceset_info->traceset_context)); + g_object_unref(mw_data->current_tab->traceset_info->traceset_context); + } + lttv_traceset_remove(traceset, i); + lttv_trace_destroy(trace_v); + mw_data->current_tab->traceset_info->traceset_context = + g_object_new(LTTV_TRACESET_STATS_TYPE, NULL); + lttv_context_init( + LTTV_TRACESET_CONTEXT(mw_data->current_tab-> + traceset_info->traceset_context),traceset); + //update current tab + // set_current_time(mw_data, &(mw_data->current_tab->current_time)); } - lttv_traceset_remove(traceset, i); - mw_data->traceset_info->traceset_context = - g_object_new(LTTV_TRACESET_STATS_TYPE, NULL); - lttv_context_init( - LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context),traceset); break; } } } g_free(name); - g_printf("remove a trace from a trace set\n"); } void save(GtkWidget * widget, gpointer user_data) @@ -292,7 +451,8 @@ void zoom(GtkWidget * widget, double size) LttTime current_time, time_delta, time_s, time_e; MainWindow * mw_data = get_window_data_struct(widget); - time_span = LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context)->Time_Span ; + time_span = LTTV_TRACESET_CONTEXT(mw_data->current_tab-> + traceset_info->traceset_context)->Time_Span; time_window = mw_data->current_tab->time_window; current_time = mw_data->current_tab->current_time; @@ -316,7 +476,7 @@ void zoom(GtkWidget * widget, double size) time_window.start_time = time_s; } set_time_window(mw_data, &time_window); - gtk_custom_set_adjust(mw_data->current_tab->custom, FALSE); + gtk_multi_vpaned_set_adjust(mw_data->current_tab->multi_vpaned, FALSE); } void zoom_in(GtkWidget * widget, gpointer user_data) @@ -368,6 +528,7 @@ on_tab_activate (GtkMenuItem *menuitem, gpointer user_data) { gchar label[PATH_LENGTH]; + MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem); GtkNotebook * notebook = (GtkNotebook *)lookup_widget((GtkWidget*)menuitem, "MNotebook"); if(notebook == NULL){ g_printf("Notebook does not exist\n"); @@ -375,9 +536,9 @@ on_tab_activate (GtkMenuItem *menuitem, } strcpy(label,"Page"); - get_label(NULL, label,"Get the name of the tab","Please input tab's name"); + get_label(mw_data, label,"Get the name of the tab","Please input tab's name"); - create_tab ((GtkWidget*)menuitem, notebook, label); + create_tab (mw_data, mw_data, notebook, label); } @@ -564,6 +725,28 @@ on_remove_viewer_activate (GtkMenuItem *menuitem, delete_viewer((GtkWidget*)menuitem, user_data); } +void +on_trace_filter_activate (GtkMenuItem *menuitem, + gpointer user_data) +{ + MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem); + LttvTracesetSelector * s; + GtkWidget * w = gtk_multi_vpaned_get_widget(mw_data->current_tab->multi_vpaned); + + s = g_object_get_data(G_OBJECT(w), "Traceset_Selector"); + if(!s){ + g_printf("There is no viewer yet\n"); + return; + } + get_filter_selection(s, "Configure trace and tracefile filter", "Select traces and tracefiles"); +} + +void +on_trace_facility_activate (GtkMenuItem *menuitem, + gpointer user_data) +{ + g_printf("Trace facility selector: %s\n"); +} void on_load_module_activate (GtkMenuItem *menuitem, @@ -843,6 +1026,152 @@ on_MNotebook_switch_page (GtkNotebook *notebook, mw->current_tab = tab; } +void checkbox_changed(GtkTreeView *treeview, + GtkTreePath *arg1, + GtkTreeViewColumn *arg2, + gpointer user_data) +{ + GtkTreeStore * store = (GtkTreeStore *)gtk_tree_view_get_model (treeview); + GtkTreeIter iter; + gboolean value; + + if (gtk_tree_model_get_iter ((GtkTreeModel *)store, &iter, arg1)){ + gtk_tree_model_get ((GtkTreeModel *)store, &iter, CHECKBOX_COLUMN, &value, -1); + value = value? FALSE : TRUE; + gtk_tree_store_set (GTK_TREE_STORE (store), &iter, CHECKBOX_COLUMN, value, -1); + } + +} + +void update_filter(LttvTracesetSelector *s, GtkTreeStore *store ) +{ + GtkTreeIter iter, child_iter; + int i, j; + LttvTraceSelector * trace; + LttvTracefileSelector * tracefile; + gboolean value, value1; + + if(gtk_tree_model_get_iter_first((GtkTreeModel*)store, &iter)){ + i = 0; + do{ + trace = lttv_traceset_selector_get(s, i); + gtk_tree_model_get ((GtkTreeModel*)store, &iter, CHECKBOX_COLUMN, &value,-1); + if(value){ + j = 0; + if(gtk_tree_model_iter_children ((GtkTreeModel*)store, &child_iter, &iter)){ + do{ + tracefile = lttv_trace_selector_get(trace, j); + gtk_tree_model_get ((GtkTreeModel*)store, &child_iter, CHECKBOX_COLUMN, &value1,-1); + lttv_tracefile_selector_set_selected(tracefile,value1); + j++; + }while(gtk_tree_model_iter_next((GtkTreeModel*)store, &child_iter)); + } + } + lttv_trace_selector_set_selected(trace,value); + i++; + }while(gtk_tree_model_iter_next((GtkTreeModel*)store, &iter)); + } +} + +void get_filter_selection(LttvTracesetSelector *s,char *title, char * column_title) +{ + GtkWidget * dialogue; + GtkTreeStore * store; + GtkWidget * tree; + GtkWidget * scroll_win; + GtkCellRenderer * renderer; + GtkTreeViewColumn * column; + GtkTreeIter iter, child_iter; + int i, j, id, nb_trace, nb_tracefile; + LttvTraceSelector * trace; + LttvTracefileSelector * tracefile; + char * name; + gboolean checked; + + dialogue = gtk_dialog_new_with_buttons(title, + NULL, + GTK_DIALOG_MODAL, + GTK_STOCK_OK,GTK_RESPONSE_ACCEPT, + GTK_STOCK_CANCEL,GTK_RESPONSE_REJECT, + NULL); + gtk_window_set_default_size((GtkWindow*)dialogue, 300, 100); + + store = gtk_tree_store_new (TOTAL_COLUMNS, G_TYPE_BOOLEAN, G_TYPE_STRING); + tree = gtk_tree_view_new_with_model (GTK_TREE_MODEL (store)); + g_object_unref (G_OBJECT (store)); + g_signal_connect (G_OBJECT (tree), "row-activated", + G_CALLBACK (checkbox_changed), + NULL); + + + renderer = gtk_cell_renderer_toggle_new (); + gtk_cell_renderer_toggle_set_radio((GtkCellRendererToggle *)renderer, FALSE); + + g_object_set (G_OBJECT (renderer),"activatable", TRUE, NULL); + + column = gtk_tree_view_column_new_with_attributes ("Checkbox", + renderer, + "active", CHECKBOX_COLUMN, + NULL); + gtk_tree_view_column_set_alignment (column, 0.5); + gtk_tree_view_column_set_fixed_width (column, 20); + gtk_tree_view_append_column (GTK_TREE_VIEW (tree), column); + + renderer = gtk_cell_renderer_text_new (); + column = gtk_tree_view_column_new_with_attributes (column_title, + renderer, + "text", NAME_COLUMN, + NULL); + gtk_tree_view_column_set_alignment (column, 0.0); + gtk_tree_view_append_column (GTK_TREE_VIEW (tree), column); + gtk_tree_view_set_headers_visible(GTK_TREE_VIEW (tree), FALSE); + + scroll_win = gtk_scrolled_window_new (NULL, NULL); + gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scroll_win), + GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC); + gtk_container_add (GTK_CONTAINER (scroll_win), tree); + + gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialogue)->vbox), scroll_win,TRUE, TRUE,0); + + gtk_widget_show(scroll_win); + gtk_widget_show(tree); + + nb_trace = lttv_traceset_selector_number(s); + for(i=0;iattributes = attributes; - new_m_window->traceset_info = g_new(TracesetInfo,1); - new_m_window->traceset_info->path = NULL ; - - - new_m_window->traceset_info->before_traceset = lttv_hooks_new(); - new_m_window->traceset_info->after_traceset = lttv_hooks_new(); - new_m_window->traceset_info->before_trace = lttv_hooks_new(); - new_m_window->traceset_info->after_trace = lttv_hooks_new(); - new_m_window->traceset_info->before_tracefile = lttv_hooks_new(); - new_m_window->traceset_info->after_tracefile = lttv_hooks_new(); - new_m_window->traceset_info->before_event = lttv_hooks_new(); - new_m_window->traceset_info->after_event = lttv_hooks_new(); - - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/traceset/before", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->before_traceset; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/traceset/after", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->after_traceset; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/trace/before", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->before_trace; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/trace/after", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->after_trace; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/tracefile/before", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->before_tracefile; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/tracefile/after", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->after_tracefile; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/event/before", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->before_event; - g_assert(lttv_iattribute_find_by_path(attributes, "hooks/event/after", - LTTV_POINTER, &value)); - *(value.v_pointer) = new_m_window->traceset_info->after_event; - - new_m_window->mwindow = new_window; new_m_window->tab = NULL; new_m_window->current_tab = NULL; new_m_window->attributes = LTTV_IATTRIBUTE(g_object_new(LTTV_ATTRIBUTE_TYPE, NULL)); if(parent){ - new_m_window->traceset_info->traceset = - lttv_traceset_copy(parent->traceset_info->traceset); - -//FIXME copy not implemented in lower level - new_m_window->traceset_info->traceset_context = - g_object_new(LTTV_TRACESET_STATS_TYPE, NULL); - lttv_context_init( - LTTV_TRACESET_CONTEXT(new_m_window->traceset_info->traceset_context), - new_m_window->traceset_info->traceset); - //new_m_window->traceset_context = parent->traceset_context; new_m_window->win_creation_data = parent->win_creation_data; }else{ - new_m_window->traceset_info->traceset = lttv_traceset_new(); - - /* Add the command line trace */ - if(g_init_trace != NULL && first_window) - lttv_traceset_add(new_m_window->traceset_info->traceset, g_init_trace); - /* NOTE : the context must be recreated if we change the traceset, - * ie : adding/removing traces */ - new_m_window->traceset_info->traceset_context = - g_object_new(LTTV_TRACESET_STATS_TYPE, NULL); - lttv_context_init( - LTTV_TRACESET_CONTEXT(new_m_window->traceset_info->traceset_context), - new_m_window->traceset_info->traceset); - new_m_window->win_creation_data = win_creation_data; } @@ -1111,7 +1377,7 @@ void construct_main_window(MainWindow * parent, WindowCreationData * win_creatio } //for now there is no name field in LttvTraceset structure //Use "Traceset" as the label for the default tab - create_tab(new_m_window->mwindow, notebook,"Traceset"); + create_tab(NULL, new_m_window, notebook,"Traceset"); g_object_set_data_full( G_OBJECT(new_m_window->mwindow), @@ -1124,6 +1390,9 @@ void construct_main_window(MainWindow * parent, WindowCreationData * win_creatio void tab_destructor(Tab * tab_instance) { + int i, nb, ref_count; + LttvTrace * trace; + if(tab_instance->attributes) g_object_unref(tab_instance->attributes); @@ -1137,17 +1406,36 @@ void tab_destructor(Tab * tab_instance) } tmp1->next = tab_instance->next; } + + if(tab_instance->traceset_info->traceset_context != NULL){ + lttv_context_fini(LTTV_TRACESET_CONTEXT(tab_instance->traceset_info-> + traceset_context)); + g_object_unref(tab_instance->traceset_info->traceset_context); + } + if(tab_instance->traceset_info->traceset != NULL) { + nb = lttv_traceset_number(tab_instance->traceset_info->traceset); + for(i = 0 ; i < nb ; i++) { + trace = lttv_traceset_get(tab_instance->traceset_info->traceset, i); + ref_count = lttv_trace_get_ref_number(trace); + if(ref_count <= 1){ + ltt_trace_close(lttv_trace(trace)); + } + lttv_trace_destroy(trace); + } + } + lttv_traceset_destroy(tab_instance->traceset_info->traceset); + g_free(tab_instance->traceset_info); g_free(tab_instance); } -void * create_tab(GtkWidget* parent, GtkNotebook * notebook, char * label) +void * create_tab(MainWindow * parent, MainWindow* current_window, + GtkNotebook * notebook, char * label) { GList * list; Tab * tmp_tab; - MainWindow * mw_data; + MainWindow * mw_data = current_window; LttTime tmp_time; - mw_data = get_window_data_struct(parent); tmp_tab = mw_data->tab; while(tmp_tab && tmp_tab->next) tmp_tab = tmp_tab->next; if(!tmp_tab){ @@ -1158,25 +1446,46 @@ void * create_tab(GtkWidget* parent, GtkNotebook * notebook, char * label) tmp_tab->next = g_new(Tab,1); tmp_tab = tmp_tab->next; } + + tmp_tab->traceset_info = g_new(TracesetInfo,1); + if(parent){ + tmp_tab->traceset_info->traceset = + lttv_traceset_copy(parent->current_tab->traceset_info->traceset); + }else{ + if(mw_data->current_tab){ + tmp_tab->traceset_info->traceset = + lttv_traceset_copy(mw_data->current_tab->traceset_info->traceset); + }else{ + tmp_tab->traceset_info->traceset = lttv_traceset_new(); + /* Add the command line trace */ + if(g_init_trace != NULL) + lttv_traceset_add(tmp_tab->traceset_info->traceset, g_init_trace); + } + } + //FIXME copy not implemented in lower level + tmp_tab->traceset_info->traceset_context = + g_object_new(LTTV_TRACESET_STATS_TYPE, NULL); + lttv_context_init( + LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context), + tmp_tab->traceset_info->traceset); + if(mw_data->current_tab){ - // Will have to read directly at the main window level, as we want - // to be able to modify a traceset on the fly. - // tmp_tab->traceStartTime = mw_data->current_tab->traceStartTime; - // tmp_tab->traceEndTime = mw_data->current_tab->traceEndTime; + // Will have to read directly at the main window level, as we want + // to be able to modify a traceset on the fly. tmp_tab->time_window = mw_data->current_tab->time_window; tmp_tab->current_time = mw_data->current_tab->current_time; }else{ - // Will have to read directly at the main window level, as we want - // to be able to modify a traceset on the fly. - // get_traceset_time_span(mw_data,&tmp_tab->traceStartTime, &tmp_tab->traceEndTime); + // Will have to read directly at the main window level, as we want + // to be able to modify a traceset on the fly. + // get_traceset_time_span(mw_data,&tmp_tab->traceStartTime, &tmp_tab->traceEndTime); tmp_tab->time_window.start_time = - LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context)->Time_Span->startTime; + LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->startTime; if(DEFAULT_TIME_WIDTH_S < - LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context)->Time_Span->endTime.tv_sec) + LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->endTime.tv_sec) tmp_time.tv_sec = DEFAULT_TIME_WIDTH_S; else tmp_time.tv_sec = - LTTV_TRACESET_CONTEXT(mw_data->traceset_info->traceset_context)->Time_Span->endTime.tv_sec; + LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->endTime.tv_sec; tmp_time.tv_nsec = 0; tmp_tab->time_window.time_width = tmp_time ; tmp_tab->current_time.tv_sec = tmp_time.tv_sec / 2; @@ -1184,9 +1493,9 @@ void * create_tab(GtkWidget* parent, GtkNotebook * notebook, char * label) } tmp_tab->attributes = LTTV_IATTRIBUTE(g_object_new(LTTV_ATTRIBUTE_TYPE, NULL)); // mw_data->current_tab = tmp_tab; - tmp_tab->custom = (GtkCustom*)gtk_custom_new(); - tmp_tab->custom->mw = mw_data; - gtk_widget_show((GtkWidget*)tmp_tab->custom); + tmp_tab->multi_vpaned = (GtkMultiVPaned*)gtk_multi_vpaned_new(); + tmp_tab->multi_vpaned->mw = mw_data; + gtk_widget_show((GtkWidget*)tmp_tab->multi_vpaned); tmp_tab->next = NULL; tmp_tab->mw = mw_data; @@ -1194,12 +1503,12 @@ void * create_tab(GtkWidget* parent, GtkNotebook * notebook, char * label) gtk_widget_show (tmp_tab->label); g_object_set_data_full( - G_OBJECT(tmp_tab->custom), + G_OBJECT(tmp_tab->multi_vpaned), "Tab_Info", tmp_tab, (GDestroyNotify)tab_destructor); - gtk_notebook_append_page(notebook, (GtkWidget*)tmp_tab->custom, tmp_tab->label); + gtk_notebook_append_page(notebook, (GtkWidget*)tmp_tab->multi_vpaned, tmp_tab->label); list = gtk_container_get_children(GTK_CONTAINER(notebook)); gtk_notebook_set_current_page(notebook,g_list_length(list)-1); }