#include <lttvwindow/gtkdirsel.h>
-#define DEFAULT_TIME_WIDTH_S 1
+static LttTime lttvwindow_default_time_width = { 1, 0 };
#define CLIP_BUF 256 // size of clipboard buffer
extern LttvTrace *g_init_trace ;
LttvTracesetContext *tsc =
LTTV_TRACESET_CONTEXT(tab->traceset_info->traceset_context);
TimeInterval time_span = tsc->time_span;
- TimeWindow new_time_window;
- LttTime new_current_time;
+ TimeWindow new_time_window = tab->time_window;
+ LttTime new_current_time = tab->current_time;
/* Set the tab's time window and current time if
* out of bounds */
new_current_time = time_span.start_time;
LttTime tmp_time;
-
- if(DEFAULT_TIME_WIDTH_S < time_span.end_time.tv_sec)
- tmp_time.tv_sec = DEFAULT_TIME_WIDTH_S;
+
+ if(ltt_time_compare(lttvwindow_default_time_width,
+ ltt_time_sub(time_span.end_time, time_span.start_time)) < 0
+ ||
+ ltt_time_compare(time_span.end_time, time_span.start_time) == 0)
+ tmp_time = lttvwindow_default_time_width;
else
- tmp_time.tv_sec = time_span.end_time.tv_sec;
- tmp_time.tv_nsec = 0;
+ tmp_time = time_span.end_time;
+
new_time_window.time_width = tmp_time ;
new_time_window.time_width_double = ltt_time_to_double(tmp_time);
new_time_window.end_time = ltt_time_add(new_time_window.start_time,
new_time_window.time_width) ;
}
- time_change_manager(tab, new_time_window);
- current_time_change_manager(tab, new_current_time);
- //FIXME : we delete the filter tree, when it should be updated.
- lttv_filter_destroy(tab->filter);
- tab->filter = NULL;
-
+
+
#if 0
/* Set scrollbar */
GtkAdjustment *adjustment = gtk_range_get_adjustment(GTK_RANGE(tab->scrollbar));
if(tmp == NULL) retval = 1;
else lttv_hooks_call(tmp,traceset);
-
+ time_change_manager(tab, new_time_window);
+ current_time_change_manager(tab, new_current_time);
+
return retval;
}
* 0 : filters updated
* 1 : no filter hooks to update; not an error.
*/
-
+#if 0
int SetFilter(Tab * tab, gpointer filter)
{
LttvHooks * tmp;
return 0;
}
-
+#endif //0
/**
}
-static void events_request_free(EventsRequest *events_request)
-{
- if(events_request == NULL) return;
-
- if(events_request->start_position != NULL)
- lttv_traceset_context_position_destroy(events_request->start_position);
- if(events_request->end_position != NULL)
- lttv_traceset_context_position_destroy(events_request->end_position);
- if(events_request->hooks != NULL)
- g_array_free(events_request->hooks, TRUE);
- if(events_request->before_chunk_traceset != NULL)
- lttv_hooks_destroy(events_request->before_chunk_traceset);
- if(events_request->before_chunk_trace != NULL)
- lttv_hooks_destroy(events_request->before_chunk_trace);
- if(events_request->before_chunk_tracefile != NULL)
- lttv_hooks_destroy(events_request->before_chunk_tracefile);
- if(events_request->event != NULL)
- lttv_hooks_destroy(events_request->event);
- if(events_request->event_by_id != NULL)
- lttv_hooks_by_id_destroy(events_request->event_by_id);
- if(events_request->after_chunk_tracefile != NULL)
- lttv_hooks_destroy(events_request->after_chunk_tracefile);
- if(events_request->after_chunk_trace != NULL)
- lttv_hooks_destroy(events_request->after_chunk_trace);
- if(events_request->after_chunk_traceset != NULL)
- lttv_hooks_destroy(events_request->after_chunk_traceset);
- if(events_request->before_request != NULL)
- lttv_hooks_destroy(events_request->before_request);
- if(events_request->after_request != NULL)
- lttv_hooks_destroy(events_request->after_request);
-
- g_free(events_request);
-}
-
-
-
/* lttvwindow_process_pending_requests
*
* This internal function gets called by g_idle, taking care of the pending
lttv_process_traceset_middle(tsc,
events_request->start_time,
G_MAXUINT, NULL);
+#ifdef DEBUG
+ g_assert(seek_count < LTTV_STATE_SAVE_INTERVAL);
+#endif //DEBUG
} else {
/* 1.1. Use current postition as start position */
if(events_request->start_position != NULL)
lttv_traceset_context_position_destroy(events_request->start_position);
- events_request->start_position = lttv_traceset_context_position_new();
+ events_request->start_position = lttv_traceset_context_position_new(tsc);
lttv_traceset_context_position_save(tsc, events_request->start_position);
/* 1.2. Remove start time */
for(i = 0; i < nb_trace; i++){
trace_v = lttv_traceset_get(tab->traceset_info->traceset, i);
trace = lttv_trace(trace_v);
- name[i] = ltt_trace_name(trace);
+ name[i] = g_quark_to_string(ltt_trace_name(trace));
}
remove_trace_name = get_remove_trace(name, nb_trace);
Contributors :\n\
\n\
Michel Dagenais (New trace format, lttv main)\n\
-Mathieu Desnoyers (Directory structure, build with automake/conf,\n\
+Mathieu Desnoyers (Kernel Tracer, Directory structure, build with automake/conf,\n\
lttv gui, control flow view, gui cooperative trace reading\n\
scheduler with interruptible foreground and background\n\
- computation, detailed event list)\n\
+ computation, detailed event list (rewrite), trace reading\n\
+ library (rewrite))\n\
Benoit Des Ligneris, Eric Clement (Cluster adaptation, work in progress)\n\
Xang-Xiu Yang (new trace reading library and converter, lttv gui, \n\
detailed event list and statistics view)\n\
LttTime start_time = new_time_window.start_time;
LttTime end_time = new_time_window.end_time;
+ g_assert(ltt_time_compare(start_time, end_time) < 0);
+
/* Set scrollbar */
GtkAdjustment *adjustment = gtk_range_get_adjustment(GTK_RANGE(tab->scrollbar));
LttTime upper = ltt_time_sub(time_span.end_time, time_span.start_time);
tab->current_time_manager_lock = FALSE;
}
+void current_position_change_manager(Tab *tab,
+ LttvTracesetContextPosition *pos)
+{
+ LttvTracesetContext *tsc =
+ LTTV_TRACESET_CONTEXT(tab->traceset_info->traceset_context);
+ TimeInterval time_span = tsc->time_span;
+
+ g_assert(lttv_process_traceset_seek_position(tsc, pos) == 0);
+ LttTime new_time = lttv_traceset_context_position_get_time(pos);
+
+ current_time_change_manager(tab, new_time);
+
+ set_current_position(tab, pos);
+}
+
+
void
on_MEntry5_value_changed (GtkSpinButton *spinbutton,
gpointer user_data)
/* We can clone the filter, as we copy the trace set also */
/* The filter must always be in sync with the trace set */
tab->filter = lttv_filter_clone(copy_tab->filter);
-
} else {
tab->traceset_info->traceset = lttv_traceset_new();
tab->filter = NULL;
}
-
#ifdef DEBUG
lttv_attribute_write_xml(
lttv_traceset_attribute(tab->traceset_info->traceset),
tab->viewer_container = gtk_vbox_new(TRUE, 2);
tab->scrollbar = gtk_hscrollbar_new(NULL);
//tab->multivpaned = gtk_multi_vpaned_new();
-
+
gtk_box_pack_start(GTK_BOX(tab->vbox),
tab->viewer_container,
TRUE, /* expand */
TRUE, /* Give the extra space to the child */
0); /* No padding */
+
+// if(copy_tab) {
+// tab->time_window = copy_tab->time_window;
+// tab->current_time = copy_tab->current_time;
+// }
/* Create the timebar */
{
// always show : not if(g_list_length(list)>1)
gtk_notebook_set_show_tabs(notebook, TRUE);
+ if(copy_tab) {
+ lttvwindow_report_time_window(tab, copy_tab->time_window);
+ lttvwindow_report_current_time(tab, copy_tab->current_time);
+ } else {
+ TimeWindow time_window;
+
+ time_window.start_time = ltt_time_zero;
+ time_window.end_time = ltt_time_add(time_window.start_time,
+ lttvwindow_default_time_width);
+ time_window.time_width = lttvwindow_default_time_width;
+ time_window.time_width_double = ltt_time_to_double(time_window.time_width);
+
+ lttvwindow_report_time_window(tab, time_window);
+ lttvwindow_report_current_time(tab, ltt_time_zero);
+ }
+
+ LttvTraceset *traceset = tab->traceset_info->traceset;
+ SetTraceset(tab, traceset);
+
return tab;
}