Added options to run different tests in module batchtest
[lttv.git] / ltt / branches / poly / lttv / modules / gui / main / src / callbacks.c
CommitLineData
e076699e 1/* This file is part of the Linux Trace Toolkit viewer
2 * Copyright (C) 2003-2004 XangXiu Yang
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License Version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
16 * MA 02111-1307, USA.
17 */
18
561eba2a 19#ifdef HAVE_CONFIG_H
20# include <config.h>
21#endif
22
23#include <gtk/gtk.h>
24#include <gmodule.h>
25
26#include "callbacks.h"
27#include "interface.h"
28#include "support.h"
2a2fa4f0 29#include <lttv/lttv.h>
637bd544 30#include <lttv/mainwindow.h>
37d0eca6 31#include <lttv/menu.h>
32#include <lttv/toolbar.h>
cef97e7c 33#include <lttv/gtktraceset.h>
6b1d3120 34#include <lttv/module.h>
fc188b78 35#include <lttv/gtkdirsel.h>
f7afe191 36#include <lttv/iattribute.h>
49bf71b5 37#include <lttv/lttvfilter.h>
a5dcde2f 38#include <ltt/trace.h>
ed3b99b6 39#include <ltt/facility.h>
6b1d3120 40
f7afe191 41#define PATH_LENGTH 256
42#define DEFAULT_TIME_WIDTH_S 1
43
49bf71b5 44extern LttvTrace *g_init_trace ;
561eba2a 45
ec25ff5e 46
47/** Array containing instanced objects. */
68b48a45 48extern GSList * g_main_window_list;
561eba2a 49
68b48a45 50static int g_win_count = 0;
7a859036 51
bca3b81f 52MainWindow * get_window_data_struct(GtkWidget * widget);
36b3c068 53char * get_unload_module(char ** loaded_module_name, int nb_module);
2176f952 54char * get_remove_trace(char ** all_trace_name, int nb_trace);
55char * get_selection(char ** all_name, int nb, char *title, char * column_title);
a8c0f09d 56gboolean get_filter_selection(LttvTracesetSelector *s, char *title, char * column_title);
716e4367 57void * create_tab(MainWindow * parent, MainWindow * current_window,
58 GtkNotebook * notebook, char * label);
561eba2a 59
68b48a45 60void insert_viewer(GtkWidget* widget, view_constructor constructor);
49bf71b5 61void update_filter(LttvTracesetSelector *s, GtkTreeStore *store );
62
63void checkbox_changed(GtkTreeView *treeview,
64 GtkTreePath *arg1,
65 GtkTreeViewColumn *arg2,
66 gpointer user_data);
67void remove_trace_from_traceset_selector(GtkMultiVPaned * paned, unsigned i);
68void add_trace_into_traceset_selector(GtkMultiVPaned * paned, LttTrace * trace);
69
70LttvTracesetSelector * construct_traceset_selector(LttvTraceset * traceset);
71
a8c0f09d 72void redraw_viewer(MainWindow * mw_data, TimeWindow * time_window);
73unsigned get_max_event_number(MainWindow * mw_data);
202f6c8f 74
49bf71b5 75enum {
76 CHECKBOX_COLUMN,
77 NAME_COLUMN,
78 TOTAL_COLUMNS
79};
561eba2a 80
36b3c068 81enum
82{
83 MODULE_COLUMN,
84 N_COLUMNS
85};
86
abe346a3 87/* Construct a selector(filter), which will be associated with a viewer,
88 * and provides an interface for user to select interested events and traces
89 */
561eba2a 90
49bf71b5 91LttvTracesetSelector * construct_traceset_selector(LttvTraceset * traceset)
92{
93 LttvTracesetSelector * s;
94 LttvTraceSelector * trace;
95 LttvTracefileSelector * tracefile;
ed3b99b6 96 LttvEventtypeSelector * eventtype;
97 int i, j, k, m;
98 int nb_trace, nb_tracefile, nb_control, nb_per_cpu, nb_facility, nb_event;
49bf71b5 99 LttvTrace * trace_v;
100 LttTrace * t;
101 LttTracefile *tf;
ed3b99b6 102 LttFacility * fac;
103 LttEventType * et;
49bf71b5 104
105 s = lttv_traceset_selector_new(lttv_traceset_name(traceset));
106 nb_trace = lttv_traceset_number(traceset);
107 for(i=0;i<nb_trace;i++){
108 trace_v = lttv_traceset_get(traceset, i);
109 t = lttv_trace(trace_v);
110 trace = lttv_trace_selector_new(t);
ed3b99b6 111 lttv_traceset_selector_trace_add(s, trace);
112
113 nb_facility = ltt_trace_facility_number(t);
114 for(k=0;k<nb_facility;k++){
115 fac = ltt_trace_facility_get(t,k);
116 nb_event = (int) ltt_facility_eventtype_number(fac);
117 for(m=0;m<nb_event;m++){
118 et = ltt_facility_eventtype_get(fac,m);
119 eventtype = lttv_eventtype_selector_new(et);
120 lttv_trace_selector_eventtype_add(trace, eventtype);
121 }
122 }
123
49bf71b5 124 nb_control = ltt_trace_control_tracefile_number(t);
125 nb_per_cpu = ltt_trace_per_cpu_tracefile_number(t);
126 nb_tracefile = nb_control + nb_per_cpu;
127
128 for(j = 0 ; j < nb_tracefile ; j++) {
129 if(j < nb_control)
130 tf = ltt_trace_control_tracefile_get(t, j);
131 else
132 tf = ltt_trace_per_cpu_tracefile_get(t, j - nb_control);
133 tracefile = lttv_tracefile_selector_new(tf);
ed3b99b6 134 lttv_trace_selector_tracefile_add(trace, tracefile);
135 lttv_eventtype_selector_copy(trace, tracefile);
49bf71b5 136 }
137 }
138 return s;
139}
140
abe346a3 141
142/* insert_viewer function constructs an instance of a viewer first,
143 * then inserts the widget of the instance into the container of the
144 * main window
145 */
146
561eba2a 147void
606309a4 148insert_viewer_wrap(GtkWidget *menuitem, gpointer user_data)
561eba2a 149{
150 guint val = 20;
606309a4 151
68b48a45 152 insert_viewer((GtkWidget*)menuitem, (view_constructor)user_data);
37d0eca6 153 // selected_hook(&val);
561eba2a 154}
155
561eba2a 156
157/* internal functions */
68b48a45 158void insert_viewer(GtkWidget* widget, view_constructor constructor)
561eba2a 159{
daecc161 160 GtkMultiVPaned * multi_vpaned;
bca3b81f 161 MainWindow * mw_data;
f9334f6f 162 GtkWidget * viewer;
49bf71b5 163 LttvTracesetSelector * s;
202f6c8f 164 TimeInterval * time_interval;
58eecf4a 165 TimeWindow time_window, t;
561eba2a 166
68b48a45 167 mw_data = get_window_data_struct(widget);
bca3b81f 168 if(!mw_data->current_tab) return;
daecc161 169 multi_vpaned = mw_data->current_tab->multi_vpaned;
561eba2a 170
49bf71b5 171 s = construct_traceset_selector(mw_data->current_tab->traceset_info->traceset);
172 viewer = (GtkWidget*)constructor(mw_data, s, "Traceset_Selector");
f9334f6f 173 if(viewer)
f0d936c0 174 {
daecc161 175 gtk_multi_vpaned_widget_add(multi_vpaned, viewer);
f0d936c0 176 // Added by MD
8af8e4c5 177 // g_object_unref(G_OBJECT(viewer));
202f6c8f 178
202f6c8f 179 time_window = mw_data->current_tab->time_window;
180 time_interval = (TimeInterval*)g_object_get_data(G_OBJECT(viewer), TRACESET_TIME_SPAN);
181 if(time_interval){
58eecf4a 182 t = time_window;
202f6c8f 183 time_window.start_time = time_interval->startTime;
184 time_window.time_width = ltt_time_sub(time_interval->endTime,time_interval->startTime);
185 }
186
a8c0f09d 187 redraw_viewer(mw_data,&time_window);
202f6c8f 188 set_current_time(mw_data,&(mw_data->current_tab->current_time));
58eecf4a 189 if(time_interval){
190 set_time_window(mw_data,&t);
191 }
f0d936c0 192 }
561eba2a 193}
194
abe346a3 195
196/* get_label function is used to get user input, it displays an input
197 * box, which allows user to input a string
198 */
199
561eba2a 200void get_label_string (GtkWidget * text, gchar * label)
201{
202 GtkEntry * entry = (GtkEntry*)text;
203 if(strlen(gtk_entry_get_text(entry))!=0)
204 strcpy(label,gtk_entry_get_text(entry));
205}
206
eb38aea5 207gboolean get_label(MainWindow * mw, gchar * str, gchar* dialogue_title, gchar * label_str)
561eba2a 208{
209 GtkWidget * dialogue;
210 GtkWidget * text;
211 GtkWidget * label;
212 gint id;
213
5723fa24 214 dialogue = gtk_dialog_new_with_buttons(dialogue_title,NULL,
561eba2a 215 GTK_DIALOG_MODAL,
216 GTK_STOCK_OK,GTK_RESPONSE_ACCEPT,
217 GTK_STOCK_CANCEL,GTK_RESPONSE_REJECT,
218 NULL);
219
6b1d3120 220 label = gtk_label_new(label_str);
561eba2a 221 gtk_widget_show(label);
222
223 text = gtk_entry_new();
224 gtk_widget_show(text);
225
226 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialogue)->vbox), label,TRUE, TRUE,0);
227 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialogue)->vbox), text,FALSE, FALSE,0);
228
229 id = gtk_dialog_run(GTK_DIALOG(dialogue));
230 switch(id){
231 case GTK_RESPONSE_ACCEPT:
232 get_label_string(text,str);
233 gtk_widget_destroy(dialogue);
234 break;
235 case GTK_RESPONSE_REJECT:
236 default:
237 gtk_widget_destroy(dialogue);
eb38aea5 238 return FALSE;
561eba2a 239 }
eb38aea5 240 return TRUE;
561eba2a 241}
242
abe346a3 243
244/* get_window_data_struct function is actually a lookup function,
245 * given a widget which is in the tree of the main window, it will
246 * return the MainWindow data structure associated with main window
247 */
248
bca3b81f 249MainWindow * get_window_data_struct(GtkWidget * widget)
561eba2a 250{
251 GtkWidget * mw;
bca3b81f 252 MainWindow * mw_data;
561eba2a 253
254 mw = lookup_widget(widget, "MWindow");
255 if(mw == NULL){
256 g_printf("Main window does not exist\n");
257 return;
258 }
259
bca3b81f 260 mw_data = (MainWindow *) g_object_get_data(G_OBJECT(mw),"mainWindow");
68b48a45 261 if(mw_data == NULL){
561eba2a 262 g_printf("Main window data does not exist\n");
263 return;
264 }
68b48a45 265 return mw_data;
561eba2a 266}
267
abe346a3 268
269/* create_new_window function, just constructs a new main window
270 */
271
68b48a45 272void create_new_window(GtkWidget* widget, gpointer user_data, gboolean clone)
561eba2a 273{
bca3b81f 274 MainWindow * parent = get_window_data_struct(widget);
561eba2a 275
561eba2a 276 if(clone){
277 g_printf("Clone : use the same traceset\n");
716e4367 278 construct_main_window(parent, NULL);
561eba2a 279 }else{
280 g_printf("Empty : traceset is set to NULL\n");
716e4367 281 construct_main_window(NULL, parent->win_creation_data);
561eba2a 282 }
283}
284
abe346a3 285
286/* move_*_viewer functions move the selected view up/down in
287 * the current tab
288 */
289
561eba2a 290void move_up_viewer(GtkWidget * widget, gpointer user_data)
291{
bca3b81f 292 MainWindow * mw = get_window_data_struct(widget);
293 if(!mw->current_tab) return;
daecc161 294 gtk_multi_vpaned_widget_move_up(mw->current_tab->multi_vpaned);
561eba2a 295}
296
297void move_down_viewer(GtkWidget * widget, gpointer user_data)
298{
bca3b81f 299 MainWindow * mw = get_window_data_struct(widget);
300 if(!mw->current_tab) return;
daecc161 301 gtk_multi_vpaned_widget_move_down(mw->current_tab->multi_vpaned);
561eba2a 302}
303
abe346a3 304
305/* delete_viewer deletes the selected viewer in the current tab
306 */
307
561eba2a 308void delete_viewer(GtkWidget * widget, gpointer user_data)
309{
bca3b81f 310 MainWindow * mw = get_window_data_struct(widget);
311 if(!mw->current_tab) return;
daecc161 312 gtk_multi_vpaned_widget_delete(mw->current_tab->multi_vpaned);
561eba2a 313}
314
abe346a3 315
316/* open_traceset will open a traceset saved in a file
317 * Right now, it is not finished yet, (not working)
318 */
319
561eba2a 320void open_traceset(GtkWidget * widget, gpointer user_data)
321{
2176f952 322 char ** dir;
323 gint id;
324 LttvTraceset * traceset;
bca3b81f 325 MainWindow * mw_data = get_window_data_struct(widget);
68b48a45 326 GtkFileSelection * file_selector =
2176f952 327 (GtkFileSelection *)gtk_file_selection_new("Select a traceset");
328
68b48a45 329 gtk_file_selection_hide_fileop_buttons(file_selector);
c64c7ea1 330
68b48a45 331 id = gtk_dialog_run(GTK_DIALOG(file_selector));
2176f952 332 switch(id){
333 case GTK_RESPONSE_ACCEPT:
334 case GTK_RESPONSE_OK:
68b48a45 335 dir = gtk_file_selection_get_selections (file_selector);
2176f952 336 traceset = lttv_traceset_load(dir[0]);
337 g_printf("Open a trace set %s\n", dir[0]);
338 //Not finished yet
339 g_strfreev(dir);
340 case GTK_RESPONSE_REJECT:
341 case GTK_RESPONSE_CANCEL:
342 default:
68b48a45 343 gtk_widget_destroy((GtkWidget*)file_selector);
2176f952 344 break;
345 }
c64c7ea1 346
561eba2a 347}
348
abe346a3 349
350/* get_max_event_number returns the event number limit used by
351 * lttv_process_traceset(LttvTracesetContext, endTime, maxNumEvents)
352 * each viewer can set the limit
353 */
354
a8c0f09d 355unsigned get_max_event_number(MainWindow * mw_data)
202f6c8f 356{
a8c0f09d 357 unsigned nb = 0, *size;
358 GtkWidget * w;
359
360 w = gtk_multi_vpaned_get_first_widget(mw_data->current_tab->multi_vpaned);
361 while(w){
362 size = (unsigned*)g_object_get_data(G_OBJECT(w), MAX_NUMBER_EVENT);
363 if(size == NULL){
364 nb = G_MAXULONG;
365 break;
366 }else{
367 if(nb < *size)
368 nb = *size;
369 }
370 w = gtk_multi_vpaned_get_next_widget(mw_data->current_tab->multi_vpaned);
371 }
372 return nb;
373}
374
abe346a3 375
376/* redraw_viewer parses the traceset first by calling
377 * process_traceset_api, then display all viewers of
378 * the current tab
379 */
380
a8c0f09d 381void redraw_viewer(MainWindow * mw_data, TimeWindow * time_window)
382{
383 unsigned max_nb_events;
384 GdkWindow * win;
385 GdkCursor * new;
386 GtkWidget* widget;
387
abe346a3 388 //set the cursor to be X shape, indicating that the computer is busy in doing its job
a8c0f09d 389 new = gdk_cursor_new(GDK_X_CURSOR);
efde9138 390 widget = lookup_widget(mw_data->mwindow, "MToolbar1");
a8c0f09d 391 win = gtk_widget_get_parent_window(widget);
392 gdk_window_set_cursor(win, new);
393 gdk_cursor_unref(new);
394 gdk_window_stick(win);
395 gdk_window_unstick(win);
396
202f6c8f 397 //update time window of each viewer, let viewer insert hooks needed by process_traceset
398 set_time_window(mw_data, time_window);
a8c0f09d 399
400 max_nb_events = get_max_event_number(mw_data);
202f6c8f 401
402 process_traceset_api(mw_data, time_window->start_time,
403 ltt_time_add(time_window->start_time,time_window->time_width),
a8c0f09d 404 max_nb_events);
202f6c8f 405
406 //call hooks to show each viewer and let them remove hooks
407 show_viewer(mw_data);
a8c0f09d 408
abe346a3 409 //set the cursor back to normal
a8c0f09d 410 gdk_window_set_cursor(win, NULL);
202f6c8f 411}
412
abe346a3 413
414/* add_trace_into_traceset_selector, each instance of a viewer has an associated
415 * selector (filter), when a trace is added into traceset, the selector should
416 * reflect the change. The function is used to update the selector
417 */
418
49bf71b5 419void add_trace_into_traceset_selector(GtkMultiVPaned * paned, LttTrace * t)
420{
ed3b99b6 421 int j, k, m, nb_tracefile, nb_control, nb_per_cpu, nb_facility, nb_event;
49bf71b5 422 LttvTracesetSelector * s;
423 LttvTraceSelector * trace;
424 LttvTracefileSelector * tracefile;
ed3b99b6 425 LttvEventtypeSelector * eventtype;
49bf71b5 426 LttTracefile * tf;
427 GtkWidget * w;
ed3b99b6 428 LttFacility * fac;
429 LttEventType * et;
49bf71b5 430
431 w = gtk_multi_vpaned_get_first_widget(paned);
432 while(w){
433 s = g_object_get_data(G_OBJECT(w), "Traceset_Selector");
49bf71b5 434
abe346a3 435 if(s){
436 trace = lttv_trace_selector_new(t);
437 lttv_traceset_selector_trace_add(s, trace);
438
439 nb_facility = ltt_trace_facility_number(t);
440 for(k=0;k<nb_facility;k++){
441 fac = ltt_trace_facility_get(t,k);
442 nb_event = (int) ltt_facility_eventtype_number(fac);
443 for(m=0;m<nb_event;m++){
444 et = ltt_facility_eventtype_get(fac,m);
445 eventtype = lttv_eventtype_selector_new(et);
446 lttv_trace_selector_eventtype_add(trace, eventtype);
447 }
448 }
449
450 nb_control = ltt_trace_control_tracefile_number(t);
451 nb_per_cpu = ltt_trace_per_cpu_tracefile_number(t);
452 nb_tracefile = nb_control + nb_per_cpu;
453
454 for(j = 0 ; j < nb_tracefile ; j++) {
455 if(j < nb_control)
456 tf = ltt_trace_control_tracefile_get(t, j);
457 else
458 tf = ltt_trace_per_cpu_tracefile_get(t, j - nb_control);
459 tracefile = lttv_tracefile_selector_new(tf);
460 lttv_trace_selector_tracefile_add(trace, tracefile);
461 lttv_eventtype_selector_copy(trace, tracefile);
462 }
463 }else g_warning("Module does not support filtering\n");
49bf71b5 464
465 w = gtk_multi_vpaned_get_next_widget(paned);
466 }
467}
468
abe346a3 469
470/* add_trace adds a trace into the current traceset. It first displays a
471 * directory selection dialogue to let user choose a trace, then recreates
472 * tracset_context, and redraws all the viewer of the current tab
473 */
474
561eba2a 475void add_trace(GtkWidget * widget, gpointer user_data)
476{
2176f952 477 LttTrace *trace;
478 LttvTrace * trace_v;
479 LttvTraceset * traceset;
94dcfb9e 480 const char * dir;
2176f952 481 gint id;
bca3b81f 482 MainWindow * mw_data = get_window_data_struct(widget);
68b48a45 483 GtkDirSelection * file_selector = (GtkDirSelection *)gtk_dir_selection_new("Select a trace");
484 gtk_dir_selection_hide_fileop_buttons(file_selector);
2176f952 485
68b48a45 486 id = gtk_dialog_run(GTK_DIALOG(file_selector));
2176f952 487 switch(id){
488 case GTK_RESPONSE_ACCEPT:
489 case GTK_RESPONSE_OK:
68b48a45 490 dir = gtk_dir_selection_get_dir (file_selector);
284675e3 491 if(!dir || strlen(dir) ==0){
492 gtk_widget_destroy((GtkWidget*)file_selector);
493 break;
494 }
2176f952 495 trace = ltt_trace_open(dir);
496 if(trace == NULL) g_critical("cannot open trace %s", dir);
497 trace_v = lttv_trace_new(trace);
716e4367 498 traceset = mw_data->current_tab->traceset_info->traceset;
499 if(mw_data->current_tab->traceset_info->traceset_context != NULL){
500 lttv_context_fini(LTTV_TRACESET_CONTEXT(mw_data->current_tab->
501 traceset_info->traceset_context));
502 g_object_unref(mw_data->current_tab->traceset_info->traceset_context);
2176f952 503 }
504 lttv_traceset_add(traceset, trace_v);
716e4367 505 mw_data->current_tab->traceset_info->traceset_context =
2176f952 506 g_object_new(LTTV_TRACESET_STATS_TYPE, NULL);
507 lttv_context_init(
716e4367 508 LTTV_TRACESET_CONTEXT(mw_data->current_tab->traceset_info->
49bf71b5 509 traceset_context),traceset);
510 add_trace_into_traceset_selector(mw_data->current_tab->multi_vpaned, trace);
511
512 gtk_widget_destroy((GtkWidget*)file_selector);
513
514 //update current tab
a8c0f09d 515 update_traceset(mw_data);
21e8c385 516
517 get_traceset_time_span(mw_data,LTTV_TRACESET_CONTEXT(mw_data->current_tab->traceset_info->traceset_context)->Time_Span);
518 if(lttv_traceset_number(mw_data->current_tab->traceset_info->traceset) == 1 ||
519 ltt_time_compare(mw_data->current_tab->current_time,
520 LTTV_TRACESET_CONTEXT(mw_data->current_tab->traceset_info->traceset_context)->Time_Span->startTime)<0){
521 mw_data->current_tab->current_time =
522 LTTV_TRACESET_CONTEXT(mw_data->current_tab->traceset_info->traceset_context)->Time_Span->startTime;
523 mw_data->current_tab->time_window.start_time = mw_data->current_tab->current_time;
524 mw_data->current_tab->time_window.time_width.tv_sec = DEFAULT_TIME_WIDTH_S;
525 mw_data->current_tab->time_window.time_width.tv_nsec = 0;
526 }
527
a8c0f09d 528 redraw_viewer(mw_data, &(mw_data->current_tab->time_window));
202f6c8f 529 set_current_time(mw_data,&(mw_data->current_tab->current_time));
49bf71b5 530 break;
2176f952 531 case GTK_RESPONSE_REJECT:
532 case GTK_RESPONSE_CANCEL:
533 default:
68b48a45 534 gtk_widget_destroy((GtkWidget*)file_selector);
2176f952 535 break;
536 }
49bf71b5 537}
538
abe346a3 539
540/* remove_trace_into_traceset_selector, each instance of a viewer has an associated
541 * selector (filter), when a trace is remove from traceset, the selector should
542 * reflect the change. The function is used to update the selector
543 */
544
49bf71b5 545void remove_trace_from_traceset_selector(GtkMultiVPaned * paned, unsigned i)
546{
547 LttvTracesetSelector * s;
548 LttvTraceSelector * t;
549 GtkWidget * w;
550
551 w = gtk_multi_vpaned_get_first_widget(paned);
552 while(w){
553 s = g_object_get_data(G_OBJECT(w), "Traceset_Selector");
abe346a3 554 if(s){
555 t = lttv_traceset_selector_trace_get(s,i);
556 lttv_traceset_selector_trace_remove(s, i);
557 lttv_trace_selector_destroy(t);
558 }g_warning("Module dose not support filtering\n");
49bf71b5 559 w = gtk_multi_vpaned_get_next_widget(paned);
560 }
561eba2a 561}
562
abe346a3 563
564/* remove_trace removes a trace from the current traceset if all viewers in
565 * the current tab are not interested in the trace. It first displays a
566 * dialogue, which shows all traces in the current traceset, to let user choose
567 * a trace, then it checks if all viewers unselect the trace, if it is true,
568 * it will remove the trace, recreate the traceset_contex,
569 * and redraws all the viewer of the current tab. If there is on trace in the
570 * current traceset, it will delete all viewers of the current tab
571 */
572
561eba2a 573void remove_trace(GtkWidget * widget, gpointer user_data)
574{
2176f952 575 LttTrace *trace;
576 LttvTrace * trace_v;
577 LttvTraceset * traceset;
578 gint i, nb_trace;
579 char ** name, *remove_trace_name;
bca3b81f 580 MainWindow * mw_data = get_window_data_struct(widget);
49bf71b5 581 LttvTracesetSelector * s;
582 LttvTraceSelector * t;
583 GtkWidget * w;
584 gboolean selected;
2176f952 585
716e4367 586 nb_trace =lttv_traceset_number(mw_data->current_tab->traceset_info->traceset);
2176f952 587 name = g_new(char*,nb_trace);
588 for(i = 0; i < nb_trace; i++){
716e4367 589 trace_v = lttv_traceset_get(mw_data->current_tab->
590 traceset_info->traceset, i);
2176f952 591 trace = lttv_trace(trace_v);
a5dcde2f 592 name[i] = ltt_trace_name(trace);
2176f952 593 }
594
595 remove_trace_name = get_remove_trace(name, nb_trace);
596
597 if(remove_trace_name){
598 for(i=0; i<nb_trace; i++){
599 if(strcmp(remove_trace_name,name[i]) == 0){
49bf71b5 600 //unselect the trace from the current viewer
601 w = gtk_multi_vpaned_get_widget(mw_data->current_tab->multi_vpaned);
9f0a7b47 602 if(w){
49bf71b5 603 s = g_object_get_data(G_OBJECT(w), "Traceset_Selector");
abe346a3 604 if(s){
605 t = lttv_traceset_selector_trace_get(s,i);
606 lttv_trace_selector_set_selected(t, FALSE);
607 }
9f0a7b47 608
609 //check if other viewers select the trace
610 w = gtk_multi_vpaned_get_first_widget(mw_data->current_tab->multi_vpaned);
611 while(w){
612 s = g_object_get_data(G_OBJECT(w), "Traceset_Selector");
abe346a3 613 if(s){
614 t = lttv_traceset_selector_trace_get(s,i);
615 selected = lttv_trace_selector_get_selected(t);
616 if(selected)break;
617 }
9f0a7b47 618 w = gtk_multi_vpaned_get_next_widget(mw_data->current_tab->multi_vpaned);
619 }
620 }else selected = FALSE;
49bf71b5 621
622 //if no viewer selects the trace, remove it
623 if(!selected){
624 remove_trace_from_traceset_selector(mw_data->current_tab->multi_vpaned, i);
625
626 traceset = mw_data->current_tab->traceset_info->traceset;
627 trace_v = lttv_traceset_get(traceset, i);
628 if(lttv_trace_get_ref_number(trace_v) <= 1)
629 ltt_trace_close(lttv_trace(trace_v));
630
631 if(mw_data->current_tab->traceset_info->traceset_context != NULL){
632 lttv_context_fini(LTTV_TRACESET_CONTEXT(mw_data->current_tab->
633 traceset_info->traceset_context));
634 g_object_unref(mw_data->current_tab->traceset_info->traceset_context);
635 }
636 lttv_traceset_remove(traceset, i);
912be9a5 637 if(!lttv_trace_get_ref_number(trace_v))
638 lttv_trace_destroy(trace_v);
49bf71b5 639 mw_data->current_tab->traceset_info->traceset_context =
640 g_object_new(LTTV_TRACESET_STATS_TYPE, NULL);
641 lttv_context_init(
642 LTTV_TRACESET_CONTEXT(mw_data->current_tab->
643 traceset_info->traceset_context),traceset);
644 //update current tab
a8c0f09d 645 update_traceset(mw_data);
912be9a5 646 if(nb_trace > 1){
647 redraw_viewer(mw_data, &(mw_data->current_tab->time_window));
648 set_current_time(mw_data,&(mw_data->current_tab->current_time));
649 }else{
650 if(mw_data->current_tab){
651 while(mw_data->current_tab->multi_vpaned->num_children){
652 gtk_multi_vpaned_widget_delete(mw_data->current_tab->multi_vpaned);
653 }
654 }
655 }
2176f952 656 }
2176f952 657 break;
658 }
659 }
660 }
661
662 g_free(name);
561eba2a 663}
664
abe346a3 665
666/* save will save the traceset to a file
667 * Not implemented yet
668 */
669
561eba2a 670void save(GtkWidget * widget, gpointer user_data)
671{
672 g_printf("Save\n");
673}
674
675void save_as(GtkWidget * widget, gpointer user_data)
676{
677 g_printf("Save as\n");
678}
679
abe346a3 680
681/* zoom will change the time_window of all the viewers of the
682 * current tab, and redisplay them. The main functionality is to
683 * determine the new time_window of the current tab
684 */
685
1f1ae829 686void zoom(GtkWidget * widget, double size)
687{
688 TimeInterval *time_span;
689 TimeWindow time_window;
a8c0f09d 690 LttTime current_time, time_delta, time_s, time_e, time_t;
1f1ae829 691 MainWindow * mw_data = get_window_data_struct(widget);
692
fda16332 693 if(size == 1) return;
694
716e4367 695 time_span = LTTV_TRACESET_CONTEXT(mw_data->current_tab->
696 traceset_info->traceset_context)->Time_Span;
1f1ae829 697 time_window = mw_data->current_tab->time_window;
698 current_time = mw_data->current_tab->current_time;
699
700 time_delta = ltt_time_sub(time_span->endTime,time_span->startTime);
701 if(size == 0){
702 time_window.start_time = time_span->startTime;
703 time_window.time_width = time_delta;
704 }else{
705 time_window.time_width = ltt_time_div(time_window.time_width, size);
706 if(ltt_time_compare(time_window.time_width,time_delta) > 0)
fda16332 707 time_window.time_width = time_delta;
1f1ae829 708
a8c0f09d 709 time_t = ltt_time_div(time_window.time_width, 2);
710 if(ltt_time_compare(current_time, time_t) < 0){
711 time_s = time_span->startTime;
712 } else {
713 time_s = ltt_time_sub(current_time,time_t);
714 }
715 time_e = ltt_time_add(current_time,time_t);
1f1ae829 716 if(ltt_time_compare(time_span->startTime, time_s) > 0){
717 time_s = time_span->startTime;
718 }else if(ltt_time_compare(time_span->endTime, time_e) < 0){
719 time_e = time_span->endTime;
720 time_s = ltt_time_sub(time_e,time_window.time_width);
721 }
722 time_window.start_time = time_s;
723 }
a8c0f09d 724 redraw_viewer(mw_data, &time_window);
202f6c8f 725 set_current_time(mw_data,&(mw_data->current_tab->current_time));
daecc161 726 gtk_multi_vpaned_set_adjust(mw_data->current_tab->multi_vpaned, FALSE);
1f1ae829 727}
728
561eba2a 729void zoom_in(GtkWidget * widget, gpointer user_data)
730{
1f1ae829 731 zoom(widget, 2);
561eba2a 732}
733
734void zoom_out(GtkWidget * widget, gpointer user_data)
735{
1f1ae829 736 zoom(widget, 0.5);
561eba2a 737}
738
739void zoom_extended(GtkWidget * widget, gpointer user_data)
740{
1f1ae829 741 zoom(widget, 0);
561eba2a 742}
743
744void go_to_time(GtkWidget * widget, gpointer user_data)
745{
746 g_printf("Go to time\n");
747}
748
749void show_time_frame(GtkWidget * widget, gpointer user_data)
750{
751 g_printf("Show time frame\n");
752}
753
754
755/* callback function */
756
757void
758on_empty_traceset_activate (GtkMenuItem *menuitem,
759 gpointer user_data)
760{
68b48a45 761 create_new_window((GtkWidget*)menuitem, user_data, FALSE);
561eba2a 762}
763
764
765void
766on_clone_traceset_activate (GtkMenuItem *menuitem,
767 gpointer user_data)
768{
68b48a45 769 create_new_window((GtkWidget*)menuitem, user_data, TRUE);
561eba2a 770}
771
abe346a3 772
773/* create_new_tab calls create_tab to construct a new tab in the main window
774 */
775
2901f314 776void create_new_tab(GtkWidget* widget, gpointer user_data){
6b1d3120 777 gchar label[PATH_LENGTH];
2901f314 778 MainWindow * mw_data = get_window_data_struct(widget);
779 GtkNotebook * notebook = (GtkNotebook *)lookup_widget(widget, "MNotebook");
561eba2a 780 if(notebook == NULL){
781 g_printf("Notebook does not exist\n");
782 return;
783 }
784
6b1d3120 785 strcpy(label,"Page");
eb38aea5 786 if(get_label(mw_data, label,"Get the name of the tab","Please input tab's name"))
787 create_tab (mw_data, mw_data, notebook, label);
561eba2a 788}
789
2901f314 790void
791on_tab_activate (GtkMenuItem *menuitem,
792 gpointer user_data)
793{
794 create_new_tab((GtkWidget*)menuitem, user_data);
795}
796
561eba2a 797
798void
799on_open_activate (GtkMenuItem *menuitem,
800 gpointer user_data)
801{
802 open_traceset((GtkWidget*)menuitem, user_data);
803}
804
805
806void
807on_close_activate (GtkMenuItem *menuitem,
808 gpointer user_data)
809{
bca3b81f 810 MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem);
68b48a45 811 main_window_destructor(mw_data);
561eba2a 812}
813
814
abe346a3 815/* remove the current tab from the main window if it is not the default tab
816 */
817
561eba2a 818void
819on_close_tab_activate (GtkMenuItem *menuitem,
820 gpointer user_data)
821{
efde9138 822 GList * list;
2061e03d 823 int count = 0;
824 GtkWidget * notebook;
bca3b81f 825 Tab * tmp;
826 MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem);
2061e03d 827 notebook = lookup_widget((GtkWidget*)menuitem, "MNotebook");
828 if(notebook == NULL){
829 g_printf("Notebook does not exist\n");
830 return;
831 }
832
bca3b81f 833 if(mw_data->tab == mw_data->current_tab){
834 // tmp = mw_data->current_tb;
835 // mw_data->tab = mw_data->current_tab->next;
2061e03d 836 g_printf("The default TAB can not be deleted\n");
837 return;
838 }else{
bca3b81f 839 tmp = mw_data->tab;
840 while(tmp != mw_data->current_tab){
841 tmp = tmp->next;
abe346a3 842 count++;
2061e03d 843 }
844 }
845
846 gtk_notebook_remove_page((GtkNotebook*)notebook, count);
efde9138 847 list = gtk_container_get_children(GTK_CONTAINER(notebook));
848 if(g_list_length(list)==1)
849 gtk_notebook_set_show_tabs((GtkNotebook*)notebook, FALSE);
561eba2a 850}
851
852
853void
854on_add_trace_activate (GtkMenuItem *menuitem,
855 gpointer user_data)
856{
857 add_trace((GtkWidget*)menuitem, user_data);
858}
859
860
861void
862on_remove_trace_activate (GtkMenuItem *menuitem,
863 gpointer user_data)
864{
865 remove_trace((GtkWidget*)menuitem, user_data);
866}
867
868
869void
870on_save_activate (GtkMenuItem *menuitem,
871 gpointer user_data)
872{
873 save((GtkWidget*)menuitem, user_data);
874}
875
876
877void
878on_save_as_activate (GtkMenuItem *menuitem,
879 gpointer user_data)
880{
881 save_as((GtkWidget*)menuitem, user_data);
882}
883
884
885void
886on_quit_activate (GtkMenuItem *menuitem,
887 gpointer user_data)
888{
2061e03d 889 gtk_main_quit ();
561eba2a 890}
891
892
893void
894on_cut_activate (GtkMenuItem *menuitem,
895 gpointer user_data)
896{
897 g_printf("Cut\n");
898}
899
900
901void
902on_copy_activate (GtkMenuItem *menuitem,
903 gpointer user_data)
904{
905 g_printf("Copye\n");
906}
907
908
909void
910on_paste_activate (GtkMenuItem *menuitem,
911 gpointer user_data)
912{
913 g_printf("Paste\n");
914}
915
916
917void
918on_delete_activate (GtkMenuItem *menuitem,
919 gpointer user_data)
920{
921 g_printf("Delete\n");
922}
923
924
925void
926on_zoom_in_activate (GtkMenuItem *menuitem,
927 gpointer user_data)
928{
929 zoom_in((GtkWidget*)menuitem, user_data);
930}
931
932
933void
934on_zoom_out_activate (GtkMenuItem *menuitem,
935 gpointer user_data)
936{
937 zoom_out((GtkWidget*)menuitem, user_data);
938}
939
940
941void
942on_zoom_extended_activate (GtkMenuItem *menuitem,
943 gpointer user_data)
944{
945 zoom_extended((GtkWidget*)menuitem, user_data);
946}
947
948
949void
950on_go_to_time_activate (GtkMenuItem *menuitem,
951 gpointer user_data)
952{
953 go_to_time((GtkWidget*)menuitem, user_data);
954}
955
956
957void
958on_show_time_frame_activate (GtkMenuItem *menuitem,
959 gpointer user_data)
960{
961 show_time_frame((GtkWidget*)menuitem, user_data);
962}
963
964
965void
966on_move_viewer_up_activate (GtkMenuItem *menuitem,
967 gpointer user_data)
968{
969 move_up_viewer((GtkWidget*)menuitem, user_data);
970}
971
972
973void
974on_move_viewer_down_activate (GtkMenuItem *menuitem,
975 gpointer user_data)
976{
977 move_down_viewer((GtkWidget*)menuitem, user_data);
978}
979
980
981void
982on_remove_viewer_activate (GtkMenuItem *menuitem,
983 gpointer user_data)
984{
985 delete_viewer((GtkWidget*)menuitem, user_data);
986}
987
49bf71b5 988void
989on_trace_filter_activate (GtkMenuItem *menuitem,
990 gpointer user_data)
991{
992 MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem);
993 LttvTracesetSelector * s;
994 GtkWidget * w = gtk_multi_vpaned_get_widget(mw_data->current_tab->multi_vpaned);
995
996 s = g_object_get_data(G_OBJECT(w), "Traceset_Selector");
997 if(!s){
998 g_printf("There is no viewer yet\n");
999 return;
1000 }
a8c0f09d 1001 if(get_filter_selection(s, "Configure trace and tracefile filter", "Select traces and tracefiles")){
1002 update_traceset(mw_data);
1003 redraw_viewer(mw_data, &(mw_data->current_tab->time_window));
1004 set_current_time(mw_data,&(mw_data->current_tab->current_time));
1005 }
49bf71b5 1006}
1007
1008void
1009on_trace_facility_activate (GtkMenuItem *menuitem,
1010 gpointer user_data)
1011{
1012 g_printf("Trace facility selector: %s\n");
1013}
561eba2a 1014
abe346a3 1015
1016/* Dispaly a file selection dialogue to let user select a module, then call
1017 * lttv_module_load(), finally insert tool button and menu entry in the main window
1018 * for the loaded module
1019 */
1020
561eba2a 1021void
1022on_load_module_activate (GtkMenuItem *menuitem,
1023 gpointer user_data)
1024{
36b3c068 1025 char ** dir;
1026 gint id;
3872a20e 1027 char str[PATH_LENGTH], *str1;
bca3b81f 1028 MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem);
68b48a45 1029 GtkFileSelection * file_selector = (GtkFileSelection *)gtk_file_selection_new("Select a module");
1030 gtk_file_selection_hide_fileop_buttons(file_selector);
36b3c068 1031
1032 str[0] = '\0';
68b48a45 1033 id = gtk_dialog_run(GTK_DIALOG(file_selector));
36b3c068 1034 switch(id){
1035 case GTK_RESPONSE_ACCEPT:
1036 case GTK_RESPONSE_OK:
68b48a45 1037 dir = gtk_file_selection_get_selections (file_selector);
36b3c068 1038 sprintf(str,dir[0]);
3872a20e 1039 str1 = strrchr(str,'/');
1040 if(str1)str1++;
1041 else{
1042 str1 = strrchr(str,'\\');
1043 str1++;
1044 }
bca3b81f 1045 if(mw_data->win_creation_data)
1046 lttv_module_load(str1, mw_data->win_creation_data->argc,mw_data->win_creation_data->argv);
36b3c068 1047 else
3872a20e 1048 lttv_module_load(str1, 0,NULL);
f2d17b4d 1049 g_slist_foreach(g_main_window_list, (gpointer)insert_menu_toolbar_item,
1050 NULL);
36b3c068 1051 g_strfreev(dir);
1052 case GTK_RESPONSE_REJECT:
1053 case GTK_RESPONSE_CANCEL:
1054 default:
68b48a45 1055 gtk_widget_destroy((GtkWidget*)file_selector);
36b3c068 1056 break;
1057 }
1058 g_printf("Load module: %s\n", str);
561eba2a 1059}
1060
1061
abe346a3 1062/* Display all loaded modules, let user to select a module to unload
1063 * by calling lttv_module_unload
1064 */
1065
561eba2a 1066void
1067on_unload_module_activate (GtkMenuItem *menuitem,
1068 gpointer user_data)
1069{
36b3c068 1070 int i;
1071 char **name, *unload_module_name;
1072 guint nb;
1073 LttvModule ** modules, *module;
bca3b81f 1074 MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem);
36b3c068 1075
1076 modules = lttv_module_list(&nb);
1077 name = g_new(char*, nb);
1078 for(i=0;i<nb;i++){
1079 module = modules[i];
1080 name[i] = lttv_module_name(module);
1081 }
1082
1083 unload_module_name =get_unload_module(name,nb);
1084
1085 if(unload_module_name){
1086 for(i=0;i<nb;i++){
1087 if(strcmp(unload_module_name, name[i]) == 0){
1088 lttv_module_unload(modules[i]);
1089 break;
1090 }
1091 }
1092 }
1093
1094 g_free(name);
561eba2a 1095}
1096
1097
abe346a3 1098/* Display a directory dialogue to let user select a path for module searching
1099 */
1100
561eba2a 1101void
1102on_add_module_search_path_activate (GtkMenuItem *menuitem,
1103 gpointer user_data)
1104{
68b48a45 1105 GtkDirSelection * file_selector = (GtkDirSelection *)gtk_dir_selection_new("Select module path");
67b98724 1106 const char * dir;
fc188b78 1107 gint id;
1108
bca3b81f 1109 MainWindow * mw_data = get_window_data_struct((GtkWidget*)menuitem);
fc188b78 1110
68b48a45 1111 id = gtk_dialog_run(GTK_DIALOG(file_selector));
fc188b78 1112 switch(id){
1113 case GTK_RESPONSE_ACCEPT:
1114 case GTK_RESPONSE_OK:
68b48a45 1115 dir = gtk_dir_selection_get_dir (file_selector);
fc188b78 1116 lttv_module_path_add(dir);
1117 case GTK_RESPONSE_REJECT:
1118 case GTK_RESPONSE_CANCEL:
1119 default:
68b48a45 1120 gtk_widget_destroy((GtkWidget*)file_selector);
fc188b78 1121 break;
6b1d3120 1122 }
561eba2a 1123}
1124
1125
1126void
1127on_color_activate (GtkMenuItem *menuitem,
1128 gpointer user_data)
1129{
1130 g_printf("Color\n");
1131}
1132
1133
1134void
1135on_filter_activate (GtkMenuItem *menuitem,
1136 gpointer user_data)
1137{
1138 g_printf("Filter\n");
1139}
1140
1141
1142void
1143on_save_configuration_activate (GtkMenuItem *menuitem,
1144 gpointer user_data)
1145{
1146 g_printf("Save configuration\n");
1147}
1148
1149
1150void
1151on_content_activate (GtkMenuItem *menuitem,
1152 gpointer user_data)
1153{
1154 g_printf("Content\n");
1155}
1156
1157
1158void
1159on_about_activate (GtkMenuItem *menuitem,
1160 gpointer user_data)
1161{
1162 g_printf("About...\n");
1163}
1164
1165
1166void
1167on_button_new_clicked (GtkButton *button,
1168 gpointer user_data)
1169{
6f7ad7ae 1170 create_new_window((GtkWidget*)button, user_data, TRUE);
561eba2a 1171}
1172
2901f314 1173void
1174on_button_new_tab_clicked (GtkButton *button,
1175 gpointer user_data)
1176{
1177 create_new_tab((GtkWidget*)button, user_data);
1178}
561eba2a 1179
1180void
1181on_button_open_clicked (GtkButton *button,
1182 gpointer user_data)
1183{
1184 open_traceset((GtkWidget*)button, user_data);
1185}
1186
1187
1188void
1189on_button_add_trace_clicked (GtkButton *button,
1190 gpointer user_data)
1191{
1192 add_trace((GtkWidget*)button, user_data);
1193}
1194
1195
1196void
1197on_button_remove_trace_clicked (GtkButton *button,
1198 gpointer user_data)
1199{
1200 remove_trace((GtkWidget*)button, user_data);
1201}
1202
1203
1204void
1205on_button_save_clicked (GtkButton *button,
1206 gpointer user_data)
1207{
1208 save((GtkWidget*)button, user_data);
1209}
1210
1211
1212void
1213on_button_save_as_clicked (GtkButton *button,
1214 gpointer user_data)
1215{
1216 save_as((GtkWidget*)button, user_data);
1217}
1218
1219
1220void
1221on_button_zoom_in_clicked (GtkButton *button,
1222 gpointer user_data)
1223{
1224 zoom_in((GtkWidget*)button, user_data);
1225}
1226
1227
1228void
1229on_button_zoom_out_clicked (GtkButton *button,
1230 gpointer user_data)
1231{
1232 zoom_out((GtkWidget*)button, user_data);
1233}
1234
1235
1236void
1237on_button_zoom_extended_clicked (GtkButton *button,
1238 gpointer user_data)
1239{
1240 zoom_extended((GtkWidget*)button, user_data);
1241}
1242
1243
1244void
1245on_button_go_to_time_clicked (GtkButton *button,
1246 gpointer user_data)
1247{
1248 go_to_time((GtkWidget*)button, user_data);
1249}
1250
1251
1252void
1253on_button_show_time_frame_clicked (GtkButton *button,
1254 gpointer user_data)
1255{
1256 show_time_frame((GtkWidget*)button, user_data);
1257}
1258
1259
1260void
1261on_button_move_up_clicked (GtkButton *button,
1262 gpointer user_data)
1263{
1264 move_up_viewer((GtkWidget*)button, user_data);
1265}
1266
1267
1268void
1269on_button_move_down_clicked (GtkButton *button,
1270 gpointer user_data)
1271{
1272 move_down_viewer((GtkWidget*)button, user_data);
1273}
1274
1275
1276void
1277on_button_delete_viewer_clicked (GtkButton *button,
1278 gpointer user_data)
1279{
1280 delete_viewer((GtkWidget*)button, user_data);
1281}
1282
1283void
1284on_MWindow_destroy (GtkObject *object,
1285 gpointer user_data)
1286{
e4d09234 1287 MainWindow *Main_Window = get_window_data_struct((GtkWidget*)object);
1288 GtkWidget *widget;
1289 Tab *tab = Main_Window->tab;
1290
68b48a45 1291 g_printf("There are : %d windows\n",g_slist_length(g_main_window_list));
561eba2a 1292
68b48a45 1293 g_win_count--;
1294 if(g_win_count == 0)
7a859036 1295 gtk_main_quit ();
561eba2a 1296}
1297
58eecf4a 1298gboolean
1299on_MWindow_configure (GtkWidget *widget,
1300 GdkEventConfigure *event,
1301 gpointer user_data)
1302{
1303 MainWindow * mw_data = get_window_data_struct((GtkWidget*)widget);
1304 float width = event->width;
1305 Tab * tab = mw_data->tab;
1306 TimeWindow time_win;
1307 double ratio;
1308 TimeInterval *time_span;
1309 LttTime time;
bd24a9af 1310
1311 // MD : removed time width modification upon resizing of the main window.
1312 // The viewers will redraw themselves completely, without time interval
1313 // modification.
1314/* while(tab){
58eecf4a 1315 if(mw_data->window_width){
1316 time_span = LTTV_TRACESET_CONTEXT(tab->traceset_info->traceset_context)->Time_Span ;
1317 time_win = tab->time_window;
1318 ratio = width / mw_data->window_width;
1319 tab->time_window.time_width = ltt_time_mul(time_win.time_width,ratio);
1320 time = ltt_time_sub(time_span->endTime, time_win.start_time);
1321 if(ltt_time_compare(time, tab->time_window.time_width) < 0){
1322 tab->time_window.time_width = time;
1323 }
1324 }
1325 tab = tab->next;
1326 }
1327
1328 mw_data->window_width = (int)width;
bd24a9af 1329 */
58eecf4a 1330 return FALSE;
1331}
561eba2a 1332
abe346a3 1333
1334/* Set current tab
1335 */
1336
561eba2a 1337void
1338on_MNotebook_switch_page (GtkNotebook *notebook,
1339 GtkNotebookPage *page,
1340 guint page_num,
1341 gpointer user_data)
1342{
bca3b81f 1343 MainWindow * mw = get_window_data_struct((GtkWidget*)notebook);
1344 Tab * tab = mw->tab;
561eba2a 1345
1346 while(page_num){
bca3b81f 1347 tab = tab->next;
561eba2a 1348 page_num--;
1349 }
bca3b81f 1350 mw->current_tab = tab;
561eba2a 1351}
1352
abe346a3 1353
1354/* callback function to check or uncheck the check box (filter)
1355 */
1356
49bf71b5 1357void checkbox_changed(GtkTreeView *treeview,
1358 GtkTreePath *arg1,
1359 GtkTreeViewColumn *arg2,
1360 gpointer user_data)
1361{
1362 GtkTreeStore * store = (GtkTreeStore *)gtk_tree_view_get_model (treeview);
1363 GtkTreeIter iter;
1364 gboolean value;
1365
1366 if (gtk_tree_model_get_iter ((GtkTreeModel *)store, &iter, arg1)){
1367 gtk_tree_model_get ((GtkTreeModel *)store, &iter, CHECKBOX_COLUMN, &value, -1);
1368 value = value? FALSE : TRUE;
1369 gtk_tree_store_set (GTK_TREE_STORE (store), &iter, CHECKBOX_COLUMN, value, -1);
1370 }
1371
1372}
1373
abe346a3 1374
1375/* According to user's selection, update selector(filter)
1376 */
1377
49bf71b5 1378void update_filter(LttvTracesetSelector *s, GtkTreeStore *store )
1379{
ed3b99b6 1380 GtkTreeIter iter, child_iter, child_iter1, child_iter2;
1381 int i, j, k, nb_eventtype;
49bf71b5 1382 LttvTraceSelector * trace;
1383 LttvTracefileSelector * tracefile;
ed3b99b6 1384 LttvEventtypeSelector * eventtype;
1385 gboolean value, value1, value2;
49bf71b5 1386
1387 if(gtk_tree_model_get_iter_first((GtkTreeModel*)store, &iter)){
1388 i = 0;
1389 do{
ed3b99b6 1390 trace = lttv_traceset_selector_trace_get(s, i);
1391 nb_eventtype = lttv_trace_selector_eventtype_number(trace);
49bf71b5 1392 gtk_tree_model_get ((GtkTreeModel*)store, &iter, CHECKBOX_COLUMN, &value,-1);
1393 if(value){
1394 j = 0;
1395 if(gtk_tree_model_iter_children ((GtkTreeModel*)store, &child_iter, &iter)){
1396 do{
ed3b99b6 1397 if(j<1){//eventtype selector for trace
1398 gtk_tree_model_get ((GtkTreeModel*)store, &child_iter, CHECKBOX_COLUMN, &value2,-1);
1399 if(value2){
1400 k=0;
1401 if(gtk_tree_model_iter_children ((GtkTreeModel*)store, &child_iter1, &child_iter)){
1402 do{
1403 eventtype = lttv_trace_selector_eventtype_get(trace,k);
1404 gtk_tree_model_get ((GtkTreeModel*)store, &child_iter1, CHECKBOX_COLUMN, &value2,-1);
1405 lttv_eventtype_selector_set_selected(eventtype,value2);
1406 k++;
1407 }while(gtk_tree_model_iter_next((GtkTreeModel*)store, &child_iter1));
1408 }
1409 }
1410 }else{ //tracefile selector
1411 tracefile = lttv_trace_selector_tracefile_get(trace, j - 1);
1412 gtk_tree_model_get ((GtkTreeModel*)store, &child_iter, CHECKBOX_COLUMN, &value1,-1);
1413 lttv_tracefile_selector_set_selected(tracefile,value1);
1414 if(value1){
1415 gtk_tree_model_iter_children((GtkTreeModel*)store, &child_iter1, &child_iter); //eventtype selector
1416 gtk_tree_model_get ((GtkTreeModel*)store, &child_iter1, CHECKBOX_COLUMN, &value2,-1);
1417 if(value2){
1418 k = 0;
1419 if(gtk_tree_model_iter_children ((GtkTreeModel*)store, &child_iter2, &child_iter1)){
1420 do{//eventtype selector for tracefile
1421 eventtype = lttv_tracefile_selector_eventtype_get(tracefile,k);
1422 gtk_tree_model_get ((GtkTreeModel*)store, &child_iter2, CHECKBOX_COLUMN, &value2,-1);
1423 lttv_eventtype_selector_set_selected(eventtype,value2);
1424 k++;
1425 }while(gtk_tree_model_iter_next((GtkTreeModel*)store, &child_iter2));
1426 }
1427 }
1428 }
1429 }
49bf71b5 1430 j++;
1431 }while(gtk_tree_model_iter_next((GtkTreeModel*)store, &child_iter));
1432 }
1433 }
1434 lttv_trace_selector_set_selected(trace,value);
1435 i++;
1436 }while(gtk_tree_model_iter_next((GtkTreeModel*)store, &iter));
1437 }
1438}
1439
abe346a3 1440
1441/* Display a dialogue showing all eventtypes and traces, let user to select the interested
1442 * eventtypes, tracefiles and traces (filter)
1443 */
1444
a8c0f09d 1445gboolean get_filter_selection(LttvTracesetSelector *s,char *title, char * column_title)
49bf71b5 1446{
1447 GtkWidget * dialogue;
1448 GtkTreeStore * store;
1449 GtkWidget * tree;
1450 GtkWidget * scroll_win;
1451 GtkCellRenderer * renderer;
1452 GtkTreeViewColumn * column;
ed3b99b6 1453 GtkTreeIter iter, child_iter, child_iter1, child_iter2;
1454 int i, j, k, id, nb_trace, nb_tracefile, nb_eventtype;
49bf71b5 1455 LttvTraceSelector * trace;
1456 LttvTracefileSelector * tracefile;
ed3b99b6 1457 LttvEventtypeSelector * eventtype;
49bf71b5 1458 char * name;
1459 gboolean checked;
1460
1461 dialogue = gtk_dialog_new_with_buttons(title,
1462 NULL,
1463 GTK_DIALOG_MODAL,
1464 GTK_STOCK_OK,GTK_RESPONSE_ACCEPT,
1465 GTK_STOCK_CANCEL,GTK_RESPONSE_REJECT,
1466 NULL);
ed3b99b6 1467 gtk_window_set_default_size((GtkWindow*)dialogue, 300, 500);
49bf71b5 1468
1469 store = gtk_tree_store_new (TOTAL_COLUMNS, G_TYPE_BOOLEAN, G_TYPE_STRING);
1470 tree = gtk_tree_view_new_with_model (GTK_TREE_MODEL (store));
1471 g_object_unref (G_OBJECT (store));
1472 g_signal_connect (G_OBJECT (tree), "row-activated",
1473 G_CALLBACK (checkbox_changed),
1474 NULL);
1475
1476
1477 renderer = gtk_cell_renderer_toggle_new ();
1478 gtk_cell_renderer_toggle_set_radio((GtkCellRendererToggle *)renderer, FALSE);
1479
1480 g_object_set (G_OBJECT (renderer),"activatable", TRUE, NULL);
1481
1482 column = gtk_tree_view_column_new_with_attributes ("Checkbox",
1483 renderer,
1484 "active", CHECKBOX_COLUMN,
1485 NULL);
1486 gtk_tree_view_column_set_alignment (column, 0.5);
1487 gtk_tree_view_column_set_fixed_width (column, 20);
1488 gtk_tree_view_append_column (GTK_TREE_VIEW (tree), column);
1489
1490 renderer = gtk_cell_renderer_text_new ();
1491 column = gtk_tree_view_column_new_with_attributes (column_title,
1492 renderer,
1493 "text", NAME_COLUMN,
1494 NULL);
1495 gtk_tree_view_column_set_alignment (column, 0.0);
1496 gtk_tree_view_append_column (GTK_TREE_VIEW (tree), column);
1497 gtk_tree_view_set_headers_visible(GTK_TREE_VIEW (tree), FALSE);
1498
1499 scroll_win = gtk_scrolled_window_new (NULL, NULL);
1500 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scroll_win),
1501 GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC);
1502 gtk_container_add (GTK_CONTAINER (scroll_win), tree);
1503
1504 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialogue)->vbox), scroll_win,TRUE, TRUE,0);
1505
1506 gtk_widget_show(scroll_win);
1507 gtk_widget_show(tree);
1508
ed3b99b6 1509 nb_trace = lttv_traceset_selector_trace_number(s);
49bf71b5 1510 for(i=0;i<nb_trace;i++){
ed3b99b6 1511 trace = lttv_traceset_selector_trace_get(s, i);
49bf71b5 1512 name = lttv_trace_selector_get_name(trace);
1513 gtk_tree_store_append (store, &iter, NULL);
1514 checked = lttv_trace_selector_get_selected(trace);
1515 gtk_tree_store_set (store, &iter,
1516 CHECKBOX_COLUMN,checked,
1517 NAME_COLUMN,name,
1518 -1);
ed3b99b6 1519
1520 gtk_tree_store_append (store, &child_iter, &iter);
1521 gtk_tree_store_set (store, &child_iter,
1522 CHECKBOX_COLUMN, checked,
1523 NAME_COLUMN,"eventtype",
1524 -1);
1525
1526 nb_eventtype = lttv_trace_selector_eventtype_number(trace);
1527 for(j=0;j<nb_eventtype;j++){
1528 eventtype = lttv_trace_selector_eventtype_get(trace,j);
1529 name = lttv_eventtype_selector_get_name(eventtype);
1530 checked = lttv_eventtype_selector_get_selected(eventtype);
1531 gtk_tree_store_append (store, &child_iter1, &child_iter);
1532 gtk_tree_store_set (store, &child_iter1,
1533 CHECKBOX_COLUMN, checked,
1534 NAME_COLUMN,name,
1535 -1);
1536 }
1537
1538 nb_tracefile = lttv_trace_selector_tracefile_number(trace);
49bf71b5 1539 for(j=0;j<nb_tracefile;j++){
ed3b99b6 1540 tracefile = lttv_trace_selector_tracefile_get(trace, j);
49bf71b5 1541 name = lttv_tracefile_selector_get_name(tracefile);
1542 gtk_tree_store_append (store, &child_iter, &iter);
1543 checked = lttv_tracefile_selector_get_selected(tracefile);
1544 gtk_tree_store_set (store, &child_iter,
1545 CHECKBOX_COLUMN, checked,
1546 NAME_COLUMN,name,
1547 -1);
ed3b99b6 1548
1549 gtk_tree_store_append (store, &child_iter1, &child_iter);
1550 gtk_tree_store_set (store, &child_iter1,
1551 CHECKBOX_COLUMN, checked,
1552 NAME_COLUMN,"eventtype",
1553 -1);
1554
1555 for(k=0;k<nb_eventtype;k++){
1556 eventtype = lttv_tracefile_selector_eventtype_get(tracefile,k);
1557 name = lttv_eventtype_selector_get_name(eventtype);
1558 checked = lttv_eventtype_selector_get_selected(eventtype);
1559 gtk_tree_store_append (store, &child_iter2, &child_iter1);
1560 gtk_tree_store_set (store, &child_iter2,
1561 CHECKBOX_COLUMN, checked,
1562 NAME_COLUMN,name,
1563 -1);
1564 }
49bf71b5 1565 }
1566 }
1567
1568 id = gtk_dialog_run(GTK_DIALOG(dialogue));
1569 switch(id){
1570 case GTK_RESPONSE_ACCEPT:
1571 case GTK_RESPONSE_OK:
1572 update_filter(s, store);
a8c0f09d 1573 gtk_widget_destroy(dialogue);
1574 return TRUE;
49bf71b5 1575 case GTK_RESPONSE_REJECT:
1576 case GTK_RESPONSE_CANCEL:
1577 default:
1578 gtk_widget_destroy(dialogue);
1579 break;
1580 }
a8c0f09d 1581 return FALSE;
49bf71b5 1582}
1583
abe346a3 1584
1585/* Select a trace which will be removed from traceset
1586 */
1587
2176f952 1588char * get_remove_trace(char ** all_trace_name, int nb_trace)
1589{
1590 return get_selection(all_trace_name, nb_trace,
1591 "Select a trace", "Trace pathname");
1592}
abe346a3 1593
1594
1595/* Select a module which will be unloaded
1596 */
1597
36b3c068 1598char * get_unload_module(char ** loaded_module_name, int nb_module)
2176f952 1599{
1600 return get_selection(loaded_module_name, nb_module,
1601 "Select an unload module", "Module pathname");
1602}
1603
abe346a3 1604
1605/* Display a dialogue which shows all selectable items, let user to
1606 * select one of them
1607 */
1608
2176f952 1609char * get_selection(char ** loaded_module_name, int nb_module,
1610 char *title, char * column_title)
36b3c068 1611{
1612 GtkWidget * dialogue;
1613 GtkWidget * scroll_win;
1614 GtkWidget * tree;
1615 GtkListStore * store;
1616 GtkTreeViewColumn * column;
1617 GtkCellRenderer * renderer;
1618 GtkTreeSelection * select;
1619 GtkTreeIter iter;
1620 gint id, i;
1621 char * unload_module_name = NULL;
1622
2176f952 1623 dialogue = gtk_dialog_new_with_buttons(title,
36b3c068 1624 NULL,
1625 GTK_DIALOG_MODAL,
1626 GTK_STOCK_OK,GTK_RESPONSE_ACCEPT,
1627 GTK_STOCK_CANCEL,GTK_RESPONSE_REJECT,
1628 NULL);
1629 gtk_window_set_default_size((GtkWindow*)dialogue, 500, 200);
1630
1631 scroll_win = gtk_scrolled_window_new (NULL, NULL);
1632 gtk_widget_show ( scroll_win);
1633 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scroll_win),
1634 GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
1635
1636 store = gtk_list_store_new (N_COLUMNS,G_TYPE_STRING);
1637 tree = gtk_tree_view_new_with_model(GTK_TREE_MODEL (store));
1638 gtk_widget_show ( tree);
1639 g_object_unref (G_OBJECT (store));
1640
1641 renderer = gtk_cell_renderer_text_new ();
2176f952 1642 column = gtk_tree_view_column_new_with_attributes (column_title,
36b3c068 1643 renderer,
1644 "text", MODULE_COLUMN,
1645 NULL);
1646 gtk_tree_view_column_set_alignment (column, 0.5);
1647 gtk_tree_view_column_set_fixed_width (column, 150);
1648 gtk_tree_view_append_column (GTK_TREE_VIEW (tree), column);
1649
1650 select = gtk_tree_view_get_selection (GTK_TREE_VIEW (tree));
1651 gtk_tree_selection_set_mode (select, GTK_SELECTION_SINGLE);
1652
1653 gtk_container_add (GTK_CONTAINER (scroll_win), tree);
1654
1655 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialogue)->vbox), scroll_win,TRUE, TRUE,0);
1656
1657 for(i=0;i<nb_module;i++){
1658 gtk_list_store_append (store, &iter);
1659 gtk_list_store_set (store, &iter, MODULE_COLUMN,loaded_module_name[i],-1);
1660 }
1661
1662 id = gtk_dialog_run(GTK_DIALOG(dialogue));
1663 switch(id){
1664 case GTK_RESPONSE_ACCEPT:
1665 case GTK_RESPONSE_OK:
1666 if (gtk_tree_selection_get_selected (select, (GtkTreeModel**)&store, &iter)){
1667 gtk_tree_model_get ((GtkTreeModel*)store, &iter, MODULE_COLUMN, &unload_module_name, -1);
1668 }
1669 case GTK_RESPONSE_REJECT:
1670 case GTK_RESPONSE_CANCEL:
1671 default:
1672 gtk_widget_destroy(dialogue);
1673 break;
1674 }
1675
1676 return unload_module_name;
1677}
5723fa24 1678
abe346a3 1679
1680/* hash funtions
1681 */
1682
2176f952 1683void main_window_destroy_hash_key(gpointer key)
2061e03d 1684{
1685 g_free(key);
1686}
1687
2176f952 1688void main_window_destroy_hash_data(gpointer data)
2061e03d 1689{
1690}
1691
1692
abe346a3 1693/* Insert menu entry and tool button into all main windows for modules
1694 * It checks whether the menu entry or tool button exists or not,
1695 * if they do not exist, then construct the widget and insert them
1696 * into all main windows
1697 */
1698
bca3b81f 1699void insert_menu_toolbar_item(MainWindow * mw, gpointer user_data)
5723fa24 1700{
1701 int i;
1702 GdkPixbuf *pixbuf;
1703 view_constructor constructor;
1704 LttvMenus * menu;
1705 LttvToolbars * toolbar;
68b48a45 1706 lttv_menu_closure *menu_item;
1707 lttv_toolbar_closure *toolbar_item;
5723fa24 1708 LttvAttributeValue value;
1709 LttvIAttribute *attributes = LTTV_IATTRIBUTE(lttv_global_attributes());
68b48a45 1710 GtkWidget * tool_menu_title_menu, *insert_view, *pixmap, *tmp;
5723fa24 1711
1712 g_assert(lttv_iattribute_find_by_path(attributes,
1713 "viewers/menu", LTTV_POINTER, &value));
1714 menu = (LttvMenus*)*(value.v_pointer);
1715
1716 if(menu){
1717 for(i=0;i<menu->len;i++){
68b48a45 1718 menu_item = &g_array_index(menu, lttv_menu_closure, i);
1719 tmp = g_hash_table_lookup(mw->hash_menu_item, g_strdup(menu_item->menuText));
3872a20e 1720 if(tmp)continue;
68b48a45 1721 constructor = menu_item->con;
bca3b81f 1722 tool_menu_title_menu = lookup_widget(mw->mwindow,"ToolMenuTitle_menu");
68b48a45 1723 insert_view = gtk_menu_item_new_with_mnemonic (menu_item->menuText);
5723fa24 1724 gtk_widget_show (insert_view);
68b48a45 1725 gtk_container_add (GTK_CONTAINER (tool_menu_title_menu), insert_view);
5723fa24 1726 g_signal_connect ((gpointer) insert_view, "activate",
68b48a45 1727 G_CALLBACK (insert_viewer_wrap),
5723fa24 1728 constructor);
68b48a45 1729 g_hash_table_insert(mw->hash_menu_item, g_strdup(menu_item->menuText),
2061e03d 1730 insert_view);
5723fa24 1731 }
1732 }
1733
1734 g_assert(lttv_iattribute_find_by_path(attributes,
1735 "viewers/toolbar", LTTV_POINTER, &value));
1736 toolbar = (LttvToolbars*)*(value.v_pointer);
1737
1738 if(toolbar){
1739 for(i=0;i<toolbar->len;i++){
68b48a45 1740 toolbar_item = &g_array_index(toolbar, lttv_toolbar_closure, i);
1741 tmp = g_hash_table_lookup(mw->hash_toolbar_item, g_strdup(toolbar_item->tooltip));
3872a20e 1742 if(tmp)continue;
68b48a45 1743 constructor = toolbar_item->con;
efde9138 1744 tool_menu_title_menu = lookup_widget(mw->mwindow,"MToolbar1");
68b48a45 1745 pixbuf = gdk_pixbuf_new_from_xpm_data ((const char**)toolbar_item->pixmap);
5723fa24 1746 pixmap = gtk_image_new_from_pixbuf(pixbuf);
68b48a45 1747 insert_view = gtk_toolbar_append_element (GTK_TOOLBAR (tool_menu_title_menu),
5723fa24 1748 GTK_TOOLBAR_CHILD_BUTTON,
1749 NULL,
1750 "",
68b48a45 1751 toolbar_item->tooltip, NULL,
5723fa24 1752 pixmap, NULL, NULL);
68b48a45 1753 gtk_label_set_use_underline (GTK_LABEL (((GtkToolbarChild*) (g_list_last (GTK_TOOLBAR (tool_menu_title_menu)->children)->data))->label), TRUE);
5723fa24 1754 gtk_widget_show (insert_view);
1755 gtk_container_set_border_width (GTK_CONTAINER (insert_view), 1);
68b48a45 1756 g_signal_connect ((gpointer) insert_view, "clicked",G_CALLBACK (insert_viewer_wrap),constructor);
1757 g_hash_table_insert(mw->hash_toolbar_item, g_strdup(toolbar_item->tooltip),
2061e03d 1758 insert_view);
5723fa24 1759 }
1760 }
1761}
1762
abe346a3 1763
1764/* Create a main window
1765 */
1766
716e4367 1767void construct_main_window(MainWindow * parent, WindowCreationData * win_creation_data)
5723fa24 1768{
2a2fa4f0 1769 g_debug("construct_main_window()");
68b48a45 1770 GtkWidget * new_window; /* New generated main window */
bca3b81f 1771 MainWindow * new_m_window;/* New main window structure */
5723fa24 1772 GtkNotebook * notebook;
f7afe191 1773 LttvIAttribute *attributes =
1774 LTTV_IATTRIBUTE(g_object_new(LTTV_ATTRIBUTE_TYPE, NULL));
1775 LttvAttributeValue value;
2061e03d 1776
bca3b81f 1777 new_m_window = g_new(MainWindow, 1);
5723fa24 1778
1779 // Add the object's information to the module's array
68b48a45 1780 g_main_window_list = g_slist_append(g_main_window_list, new_m_window);
5723fa24 1781
f7afe191 1782
68b48a45 1783 new_window = create_MWindow();
1784 gtk_widget_show (new_window);
5723fa24 1785
bca3b81f 1786 new_m_window->attributes = attributes;
f7afe191 1787
bca3b81f 1788 new_m_window->mwindow = new_window;
1789 new_m_window->tab = NULL;
1790 new_m_window->current_tab = NULL;
1791 new_m_window->attributes = LTTV_IATTRIBUTE(g_object_new(LTTV_ATTRIBUTE_TYPE, NULL));
5723fa24 1792 if(parent){
bca3b81f 1793 new_m_window->win_creation_data = parent->win_creation_data;
5723fa24 1794 }else{
bca3b81f 1795 new_m_window->win_creation_data = win_creation_data;
5723fa24 1796 }
1797
68b48a45 1798 new_m_window->hash_menu_item = g_hash_table_new_full (g_str_hash, g_str_equal,
2176f952 1799 main_window_destroy_hash_key,
1800 main_window_destroy_hash_data);
68b48a45 1801 new_m_window->hash_toolbar_item = g_hash_table_new_full (g_str_hash, g_str_equal,
2176f952 1802 main_window_destroy_hash_key,
1803 main_window_destroy_hash_data);
2061e03d 1804
68b48a45 1805 insert_menu_toolbar_item(new_m_window, NULL);
5723fa24 1806
68b48a45 1807 g_object_set_data(G_OBJECT(new_window), "mainWindow", (gpointer)new_m_window);
5723fa24 1808
1809 //create a default tab
bca3b81f 1810 notebook = (GtkNotebook *)lookup_widget(new_m_window->mwindow, "MNotebook");
5723fa24 1811 if(notebook == NULL){
1812 g_printf("Notebook does not exist\n");
1813 return;
1814 }
1815 //for now there is no name field in LttvTraceset structure
1816 //Use "Traceset" as the label for the default tab
6f7ad7ae 1817 create_tab(parent, new_m_window, notebook,"Traceset");
5723fa24 1818
7a859036 1819 g_object_set_data_full(
bca3b81f 1820 G_OBJECT(new_m_window->mwindow),
7a859036 1821 "Main_Window_Data",
68b48a45 1822 new_m_window,
1823 (GDestroyNotify)main_window_free);
7a859036 1824
68b48a45 1825 g_win_count++;
5723fa24 1826}
1827
abe346a3 1828
1829/* Free the memory occupied by a tab structure
1830 * destroy the tab
1831 */
1832
bca3b81f 1833void tab_destructor(Tab * tab_instance)
f7afe191 1834{
716e4367 1835 int i, nb, ref_count;
1836 LttvTrace * trace;
1837
bca3b81f 1838 if(tab_instance->attributes)
1839 g_object_unref(tab_instance->attributes);
2061e03d 1840
bca3b81f 1841 if(tab_instance->mw->tab == tab_instance){
1842 tab_instance->mw->tab = tab_instance->next;
2061e03d 1843 }else{
bca3b81f 1844 Tab * tmp1, *tmp = tab_instance->mw->tab;
68b48a45 1845 while(tmp != tab_instance){
2061e03d 1846 tmp1 = tmp;
bca3b81f 1847 tmp = tmp->next;
2061e03d 1848 }
bca3b81f 1849 tmp1->next = tab_instance->next;
2061e03d 1850 }
716e4367 1851
1852 if(tab_instance->traceset_info->traceset_context != NULL){
1853 lttv_context_fini(LTTV_TRACESET_CONTEXT(tab_instance->traceset_info->
1854 traceset_context));
1855 g_object_unref(tab_instance->traceset_info->traceset_context);
1856 }
1857 if(tab_instance->traceset_info->traceset != NULL) {
1858 nb = lttv_traceset_number(tab_instance->traceset_info->traceset);
1859 for(i = 0 ; i < nb ; i++) {
1860 trace = lttv_traceset_get(tab_instance->traceset_info->traceset, i);
1861 ref_count = lttv_trace_get_ref_number(trace);
49bf71b5 1862 if(ref_count <= 1){
716e4367 1863 ltt_trace_close(lttv_trace(trace));
6f7ad7ae 1864 lttv_trace_destroy(trace);
49bf71b5 1865 }
6f7ad7ae 1866 // lttv_trace_destroy(trace);
716e4367 1867 }
1868 }
1869 lttv_traceset_destroy(tab_instance->traceset_info->traceset);
1870 g_free(tab_instance->traceset_info);
68b48a45 1871 g_free(tab_instance);
f7afe191 1872}
1873
abe346a3 1874
1875/* Create a tab and insert it into the current main window
1876 */
1877
716e4367 1878void * create_tab(MainWindow * parent, MainWindow* current_window,
1879 GtkNotebook * notebook, char * label)
5723fa24 1880{
1881 GList * list;
bca3b81f 1882 Tab * tmp_tab;
716e4367 1883 MainWindow * mw_data = current_window;
68b48a45 1884 LttTime tmp_time;
1885
abe346a3 1886 //create a new tab data structure
bca3b81f 1887 tmp_tab = mw_data->tab;
1888 while(tmp_tab && tmp_tab->next) tmp_tab = tmp_tab->next;
68b48a45 1889 if(!tmp_tab){
bca3b81f 1890 mw_data->current_tab = NULL;
1891 tmp_tab = g_new(Tab,1);
1892 mw_data->tab = tmp_tab;
5723fa24 1893 }else{
bca3b81f 1894 tmp_tab->next = g_new(Tab,1);
1895 tmp_tab = tmp_tab->next;
5723fa24 1896 }
716e4367 1897
abe346a3 1898 //construct and initialize the traceset_info
716e4367 1899 tmp_tab->traceset_info = g_new(TracesetInfo,1);
1900 if(parent){
1901 tmp_tab->traceset_info->traceset =
1902 lttv_traceset_copy(parent->current_tab->traceset_info->traceset);
1903 }else{
1904 if(mw_data->current_tab){
1905 tmp_tab->traceset_info->traceset =
1906 lttv_traceset_copy(mw_data->current_tab->traceset_info->traceset);
1907 }else{
1908 tmp_tab->traceset_info->traceset = lttv_traceset_new();
49bf71b5 1909 /* Add the command line trace */
1910 if(g_init_trace != NULL)
1911 lttv_traceset_add(tmp_tab->traceset_info->traceset, g_init_trace);
716e4367 1912 }
716e4367 1913 }
1914 //FIXME copy not implemented in lower level
1915 tmp_tab->traceset_info->traceset_context =
1916 g_object_new(LTTV_TRACESET_STATS_TYPE, NULL);
1917 lttv_context_init(
1918 LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context),
1919 tmp_tab->traceset_info->traceset);
1920
abe346a3 1921 //determine the current_time and time_window of the tab
bca3b81f 1922 if(mw_data->current_tab){
716e4367 1923 // Will have to read directly at the main window level, as we want
1924 // to be able to modify a traceset on the fly.
bca3b81f 1925 tmp_tab->time_window = mw_data->current_tab->time_window;
1926 tmp_tab->current_time = mw_data->current_tab->current_time;
5723fa24 1927 }else{
716e4367 1928 // Will have to read directly at the main window level, as we want
1929 // to be able to modify a traceset on the fly.
1930 // get_traceset_time_span(mw_data,&tmp_tab->traceStartTime, &tmp_tab->traceEndTime);
bca3b81f 1931 tmp_tab->time_window.start_time =
716e4367 1932 LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->startTime;
f7afe191 1933 if(DEFAULT_TIME_WIDTH_S <
716e4367 1934 LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->endTime.tv_sec)
68b48a45 1935 tmp_time.tv_sec = DEFAULT_TIME_WIDTH_S;
f7afe191 1936 else
68b48a45 1937 tmp_time.tv_sec =
716e4367 1938 LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->endTime.tv_sec;
68b48a45 1939 tmp_time.tv_nsec = 0;
bca3b81f 1940 tmp_tab->time_window.time_width = tmp_time ;
a8c0f09d 1941 tmp_tab->current_time.tv_sec =
1942 LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->startTime.tv_sec;
1943 tmp_tab->current_time.tv_nsec =
1944 LTTV_TRACESET_CONTEXT(tmp_tab->traceset_info->traceset_context)->Time_Span->startTime.tv_nsec;
5723fa24 1945 }
bca3b81f 1946 tmp_tab->attributes = LTTV_IATTRIBUTE(g_object_new(LTTV_ATTRIBUTE_TYPE, NULL));
1947 // mw_data->current_tab = tmp_tab;
daecc161 1948 tmp_tab->multi_vpaned = (GtkMultiVPaned*)gtk_multi_vpaned_new();
1949 tmp_tab->multi_vpaned->mw = mw_data;
1950 gtk_widget_show((GtkWidget*)tmp_tab->multi_vpaned);
bca3b81f 1951 tmp_tab->next = NULL;
68b48a45 1952 tmp_tab->mw = mw_data;
5723fa24 1953
68b48a45 1954 tmp_tab->label = gtk_label_new (label);
1955 gtk_widget_show (tmp_tab->label);
5723fa24 1956
f7afe191 1957 g_object_set_data_full(
daecc161 1958 G_OBJECT(tmp_tab->multi_vpaned),
f7afe191 1959 "Tab_Info",
68b48a45 1960 tmp_tab,
1961 (GDestroyNotify)tab_destructor);
540edb40 1962
abe346a3 1963 //add state update hooks
540edb40 1964 lttv_state_add_event_hooks(
1965 (LttvTracesetState*)tmp_tab->traceset_info->traceset_context);
5723fa24 1966
abe346a3 1967 //insert tab into notebook
daecc161 1968 gtk_notebook_append_page(notebook, (GtkWidget*)tmp_tab->multi_vpaned, tmp_tab->label);
5723fa24 1969 list = gtk_container_get_children(GTK_CONTAINER(notebook));
1970 gtk_notebook_set_current_page(notebook,g_list_length(list)-1);
efde9138 1971 if(g_list_length(list)>1)
1972 gtk_notebook_set_show_tabs(notebook, TRUE);
5723fa24 1973}
2061e03d 1974
abe346a3 1975
1976/* Remove menu entry and tool button from main window for the
1977 * unloaded module
1978 */
1979
2061e03d 1980void remove_menu_item(gpointer main_win, gpointer user_data)
1981{
bca3b81f 1982 MainWindow * mw = (MainWindow *) main_win;
68b48a45 1983 lttv_menu_closure *menu_item = (lttv_menu_closure *)user_data;
1984 GtkWidget * tool_menu_title_menu, *insert_view;
2061e03d 1985
bca3b81f 1986 tool_menu_title_menu = lookup_widget(mw->mwindow,"ToolMenuTitle_menu");
2061e03d 1987 insert_view = (GtkWidget*)g_hash_table_lookup(mw->hash_menu_item,
68b48a45 1988 menu_item->menuText);
2061e03d 1989 if(insert_view){
68b48a45 1990 g_hash_table_remove(mw->hash_menu_item, menu_item->menuText);
1991 gtk_container_remove (GTK_CONTAINER (tool_menu_title_menu), insert_view);
2061e03d 1992 }
1993}
1994
1995void remove_toolbar_item(gpointer main_win, gpointer user_data)
1996{
bca3b81f 1997 MainWindow * mw = (MainWindow *) main_win;
68b48a45 1998 lttv_toolbar_closure *toolbar_item = (lttv_toolbar_closure *)user_data;
1999 GtkWidget * tool_menu_title_menu, *insert_view;
2061e03d 2000
2001
efde9138 2002 tool_menu_title_menu = lookup_widget(mw->mwindow,"MToolbar1");
2061e03d 2003 insert_view = (GtkWidget*)g_hash_table_lookup(mw->hash_toolbar_item,
68b48a45 2004 toolbar_item->tooltip);
2061e03d 2005 if(insert_view){
68b48a45 2006 g_hash_table_remove(mw->hash_toolbar_item, toolbar_item->tooltip);
2007 gtk_container_remove (GTK_CONTAINER (tool_menu_title_menu), insert_view);
2061e03d 2008 }
2009}
2010
2011/**
abe346a3 2012 * Remove menu and toolbar item when a module unloaded from all
2013 * main windows
2061e03d 2014 */
2176f952 2015
2061e03d 2016void main_window_remove_menu_item(lttv_constructor constructor)
2017{
2018 int i;
2019 LttvMenus * menu;
68b48a45 2020 lttv_menu_closure *menu_item;
2061e03d 2021 LttvAttributeValue value;
2022 LttvIAttribute *attributes = LTTV_IATTRIBUTE(lttv_global_attributes());
2023
2024 g_assert(lttv_iattribute_find_by_path(attributes,
2025 "viewers/menu", LTTV_POINTER, &value));
2026 menu = (LttvMenus*)*(value.v_pointer);
2027
2028 if(menu){
2029 for(i=0;i<menu->len;i++){
68b48a45 2030 menu_item = &g_array_index(menu, lttv_menu_closure, i);
2031 if(menu_item->con != constructor) continue;
2032 if(g_main_window_list){
2033 g_slist_foreach(g_main_window_list, remove_menu_item, menu_item);
2176f952 2034 }
2061e03d 2035 break;
2036 }
2037 }
2038
2039}
2040
2041void main_window_remove_toolbar_item(lttv_constructor constructor)
2042{
2043 int i;
2044 LttvToolbars * toolbar;
68b48a45 2045 lttv_toolbar_closure *toolbar_item;
2061e03d 2046 LttvAttributeValue value;
2047 LttvIAttribute *attributes = LTTV_IATTRIBUTE(lttv_global_attributes());
2048
2049 g_assert(lttv_iattribute_find_by_path(attributes,
2050 "viewers/toolbar", LTTV_POINTER, &value));
2051 toolbar = (LttvToolbars*)*(value.v_pointer);
2052
2053 if(toolbar){
2054 for(i=0;i<toolbar->len;i++){
68b48a45 2055 toolbar_item = &g_array_index(toolbar, lttv_toolbar_closure, i);
2056 if(toolbar_item->con != constructor) continue;
2057 if(g_main_window_list){
2058 g_slist_foreach(g_main_window_list, remove_toolbar_item, toolbar_item);
2176f952 2059 }
2061e03d 2060 break;
2061 }
2062 }
2063}
This page took 0.124763 seconds and 4 git commands to generate.