#include <gtk/gtk.h>
#include <gdk/gdk.h>
-#include <lttv/module.h>
-#include <lttv/hook.h>
-#include <lttvwindow/viewer.h>
-#include <lttv/tracecontext.h>
-#include <lttv/state.h>
#include <ltt/ltt.h>
#include <ltt/event.h>
#include <ltt/type.h>
#include <ltt/trace.h>
#include <ltt/facility.h>
-#include <string.h>
-
-#include "gtktreeprivate.h"
+#include <lttv/module.h>
+#include <lttv/hook.h>
+#include <lttv/tracecontext.h>
+#include <lttv/state.h>
+#include <lttvwindow/lttvwindow.h>
#include "hGuiEventsInsert.xpm"
+#define MAX_NUMBER_EVENT "max_number_event"
-static LttvHooks *before_event;
/** Array containing instanced objects. Used when module is unloaded */
static GSList *g_event_viewer_data_list = NULL ;
typedef struct _EventViewerData {
- MainWindow * mw;
+ Tab * tab;
//TimeWindow time_window;
// LttTime current_time;
- LttvHooks * before_event_hooks;
+ LttvHooks * event_hooks;
gboolean append; //prepend or append item
GQueue * raw_trace_data_queue; //buf to contain raw trace data
/* Widget to display the data in a columned list */
GtkWidget *tree_v;
GtkAdjustment *vtree_adjust_c ;
+ GtkWidget *button; /* a button of the header */
+ gint header_height;
/* Vertical scrollbar and it's adjustment */
GtkWidget *vscroll_vc;
/** hook functions for update time interval, current time ... */
gboolean update_time_window(void * hook_data, void * call_data);
gboolean update_current_time(void * hook_data, void * call_data);
-gboolean show_event_detail(void * hook_data, void * call_data);
+//gboolean show_event_detail(void * hook_data, void * call_data);
gboolean traceset_changed(void * hook_data, void * call_data);
void remove_item_from_queue(GQueue * q, gboolean fromHead);
void remove_all_items_from_queue(GQueue * q);
LttvTracesetContext * tsc);
//! Event Viewer's constructor hook
-GtkWidget *h_gui_events(MainWindow *parent_window, LttvTracesetSelector * s, char* key);
+GtkWidget *h_gui_events(Tab *tab, LttvTracesetSelector * s, char* key);
//! Event Viewer's constructor
-EventViewerData *gui_events(MainWindow *parent_window, LttvTracesetSelector *s, char *key);
+EventViewerData *gui_events(Tab *tab, LttvTracesetSelector *s, char *key);
//! Event Viewer's destructor
void gui_events_destructor(EventViewerData *event_viewer_data);
void gui_events_free(EventViewerData *event_viewer_data);
static int event_selected_hook(void *hook_data, void *call_data);
+static gboolean
+header_size_allocate(GtkWidget *widget,
+ GtkAllocation *allocation,
+ gpointer user_data);
+
void tree_v_set_cursor(EventViewerData *event_viewer_data);
void tree_v_get_cursor(EventViewerData *event_viewer_data);
static void get_events(EventViewerData* event_viewer_data, LttTime start,
LttTime end, unsigned max_num_events, unsigned * real_num_events);
+int after_get_events(void *hook_data, void *call_data);
static gboolean parse_event(void *hook_data, void *call_data);
static LttvModule *main_win_module;
* @return The widget created.
*/
GtkWidget *
-h_gui_events(MainWindow * parent_window, LttvTracesetSelector * s, char* key)
+h_gui_events(Tab * tab, LttvTracesetSelector * s, char* key)
{
- EventViewerData* event_viewer_data = gui_events(parent_window, s, key) ;
+ EventViewerData* event_viewer_data = gui_events(tab, s, key) ;
if(event_viewer_data)
return event_viewer_data->hbox_v;
* @return The Event viewer data created.
*/
EventViewerData *
-gui_events(MainWindow *parent_window, LttvTracesetSelector * s,char* key )
+gui_events(Tab *tab, LttvTracesetSelector * s,char* key )
{
- LttTime start, end;
+ LttTime start;
GtkTreeViewColumn *column;
GtkCellRenderer *renderer;
EventViewerData* event_viewer_data = g_new(EventViewerData,1) ;
RawTraceData * data;
- event_viewer_data->mw = parent_window;
+ event_viewer_data->tab = tab;
- event_viewer_data->before_event_hooks = lttv_hooks_new();
- lttv_hooks_add(event_viewer_data->before_event_hooks, parse_event, event_viewer_data);
+ event_viewer_data->event_hooks = lttv_hooks_new();
+ lttv_hooks_add(event_viewer_data->event_hooks, parse_event, event_viewer_data, LTTV_PRIO_DEFAULT);
event_viewer_data->raw_trace_data_queue = g_queue_new();
event_viewer_data->raw_trace_data_queue_tmp = g_queue_new();
- lttvwindow_register_time_window_notify(event_viewer_data->mw,
+ lttvwindow_register_time_window_notify(tab,
update_time_window, event_viewer_data);
- lttvwindow_register_current_time_notify(event_viewer_data->mw,
+ lttvwindow_register_current_time_notify(tab,
update_current_time,event_viewer_data);
- lttvwindow_register_show_notify(event_viewer_data->mw,
- show_event_detail,event_viewer_data);
- lttvwindow_register_traceset_notify(event_viewer_data->mw,
+ //lttvwindow_register_show_notify(tab,
+ // show_event_detail,event_viewer_data);
+ lttvwindow_register_traceset_notify(tab,
traceset_changed,event_viewer_data);
event_viewer_data->scroll_win = gtk_scrolled_window_new (NULL, NULL);
gtk_tree_view_column_set_fixed_width (column, 45);
gtk_tree_view_append_column (GTK_TREE_VIEW (event_viewer_data->tree_v), column);
+ event_viewer_data->button = column->button;
+
+ g_signal_connect (G_OBJECT(event_viewer_data->button),
+ "size-allocate",
+ G_CALLBACK(header_size_allocate),
+ (gpointer)event_viewer_data);
+
renderer = gtk_cell_renderer_text_new ();
column = gtk_tree_view_column_new_with_attributes ("Event",
renderer,
gtk_tree_view_append_column (GTK_TREE_VIEW (event_viewer_data->tree_v), column);
renderer = gtk_cell_renderer_text_new ();
- column = gtk_tree_view_column_new_with_attributes ("Event's Description",
+ column = gtk_tree_view_column_new_with_attributes ("Event Description",
renderer,
"text", EVENT_DESCR_COLUMN,
NULL);
event_viewer_data->num_visible_events = 1;
//get the life span of the traceset and set the upper of the scroll bar
- const TimeInterval *time_span =
- lttvwindow_get_time_span(event_viewer_data->mw);
- start = ltt_time_sub(time_span->endTime, time_span->startTime);
+ LttvTracesetContext * tsc =
+ lttvwindow_get_traceset_context(event_viewer_data->tab);
+ TimeInterval time_span = tsc->time_span;
+ start = ltt_time_sub(time_span.end_time, time_span.start_time);
+
event_viewer_data->vadjust_c->upper =
ltt_time_to_double(start) * NANOSECONDS_PER_SECOND;
event_viewer_data,
(GDestroyNotify)gui_events_free);
+
return event_viewer_data;
}
+
+
+static gboolean
+header_size_allocate(GtkWidget *widget,
+ GtkAllocation *allocation,
+ gpointer user_data)
+{
+ EventViewerData *event_viewer_data = (EventViewerData*)user_data;
+
+ event_viewer_data->header_height = allocation->height;
+
+ return 0;
+}
+
+
void tree_v_set_cursor(EventViewerData *event_viewer_data)
{
GtkTreePath *path;
void tree_v_cursor_changed_cb (GtkWidget *widget, gpointer data)
{
EventViewerData *event_viewer_data = (EventViewerData*) data;
- const LttTime* current_time =
- lttvwindow_get_current_time(event_viewer_data->mw);
+ Tab *tab = event_viewer_data->tab;
+ LttTime current_time = lttvwindow_get_current_time(tab);
LttTime ltt_time;
guint64 time;
GtkTreeIter iter;
ltt_time.tv_sec = time / NANOSECONDS_PER_SECOND;
ltt_time.tv_nsec = time % NANOSECONDS_PER_SECOND;
- if(ltt_time.tv_sec != current_time->tv_sec ||
- ltt_time.tv_nsec != current_time->tv_nsec){
+ if(ltt_time.tv_sec != current_time.tv_sec ||
+ ltt_time.tv_nsec != current_time.tv_nsec){
event_viewer_data->current_time_updated = TRUE;
- lttvwindow_report_current_time(event_viewer_data->mw,<t_time);
+ lttvwindow_report_current_time(tab,<t_time);
}
}else{
g_warning("Can not get iter\n");
gdouble exact_num_visible;
exact_num_visible = ( alloc->height -
- TREE_VIEW_HEADER_HEIGHT (GTK_TREE_VIEW(event_viewer_data->tree_v)) )
- / (double)cell_height ;
+ event_viewer_data->header_height )
+ / (double)cell_height ;
event_viewer_data->num_visible_events = ceil(exact_num_visible) ;
EventViewerData *event_viewer_data = (EventViewerData*)data;
gint cell_height = get_cell_height(GTK_TREE_VIEW(event_viewer_data->tree_v));
- h = cell_height + TREE_VIEW_HEADER_HEIGHT
- (GTK_TREE_VIEW(event_viewer_data->tree_v));
+ h = cell_height + event_viewer_data->header_height;
requisition->height = h;
}
+#if 0
gboolean show_event_detail(void * hook_data, void * call_data)
{
EventViewerData *event_viewer_data = (EventViewerData*) hook_data;
- LttvTracesetContext * tsc = lttvwindow_get_traceset_context(event_viewer_data->mw);
+ LttvTracesetContext * tsc = lttvwindow_get_traceset_context(event_viewer_data->tab);
if(event_viewer_data->raw_trace_data_queue_tmp->length == 0 &&
event_viewer_data->raw_trace_data_queue->length == 0){
return FALSE;
}
+#endif //0
+
void insert_data_into_model(EventViewerData *event_viewer_data, int start, int end)
{
}
}
-void get_test_data(double time_value, guint list_height,
- EventViewerData *event_viewer_data)
+static void get_test_data_wrapped(double time_value, guint list_height,
+ EventViewerData *event_viewer_data, LttEvent *ev);
+void get_test_data(double time_value, guint list_height,
+ EventViewerData *event_viewer_data)
+{
+ LttEvent * ev = ltt_event_new();
+
+ get_test_data_wrapped(time_value, list_height,
+ event_viewer_data, ev);
+
+ ltt_event_destroy(ev);
+}
+
+static void get_test_data_wrapped(double time_value, guint list_height,
+ EventViewerData *event_viewer_data, LttEvent *ev)
{
GtkTreeIter iter;
int i;
int event_number;
double value = event_viewer_data->previous_value - time_value;
LttTime start, end, time;
- LttEvent * ev;
unsigned backward_num, minNum, maxNum;
LttTracefile * tf;
unsigned block_num, event_num;
unsigned size = 1, count = 0;
gboolean need_backward_again, backward;
GdkWindow * win;
- GdkCursor * new;
+ //GdkCursor * new;
GtkWidget* widget = gtk_widget_get_parent(event_viewer_data->hbox_v);
- const TimeInterval *time_span =
- lttvwindow_get_time_span(event_viewer_data->mw);
-
- if(widget){
- new = gdk_cursor_new(GDK_X_CURSOR);
- win = gtk_widget_get_parent_window(widget);
- gdk_window_set_cursor(win, new);
- gdk_cursor_unref(new);
- gdk_window_stick(win);
- gdk_window_unstick(win);
- }
+ LttvTracesetContext * tsc =
+ lttvwindow_get_traceset_context(event_viewer_data->tab);
+ TimeInterval time_span = tsc->time_span;
+
+ //if(widget){
+ // new = gdk_cursor_new(GDK_X_CURSOR);
+ // win = gtk_widget_get_parent_window(widget);
+ // gdk_window_set_cursor(win, new);
+ // gdk_cursor_unref(new);
+ // gdk_window_stick(win);
+ // gdk_window_unstick(win);
+ //}
// if(event_number > event_viewer_data->last_event ||
? event_num - RESERVE_SMALL_SIZE : 1;
ltt_event_position_set(raw_data->ep, block_num, backward_num);
ltt_tracefile_seek_position(tf, raw_data->ep);
- ev = ltt_tracefile_read(tf);
+ g_assert(ltt_tracefile_read(tf,ev) != NULL);
start = ltt_event_time(ev);
maxNum = RESERVE_SMALL_SIZE_CUBE;
}else{
if(block_num > 1){
ltt_event_position_set(raw_data->ep, block_num-1, 1);
ltt_tracefile_seek_position(tf, raw_data->ep);
- ev = ltt_tracefile_read(tf);
+ g_assert(ltt_tracefile_read(tf,ev) != NULL);
start = ltt_event_time(ev);
}else{
start.tv_sec = 0;
if(block_num > count){
ltt_event_position_set(raw_data->ep, block_num-count, 1);
ltt_tracefile_seek_position(tf, raw_data->ep);
- ev = ltt_tracefile_read(tf);
+ g_assert(ltt_tracefile_read(tf, ev) != NULL);
start = ltt_event_time(ev);
}else{
start.tv_sec = 0;
end.tv_sec = G_MAXULONG;
end.tv_nsec = G_MAXULONG;
time = ltt_time_from_double(time_value / NANOSECONDS_PER_SECOND);
- start = ltt_time_add(time_span->startTime, time);
+ start = ltt_time_add(time_span.start_time, time);
event_viewer_data->previous_value = time_value;
get_events(event_viewer_data, start, end, RESERVE_SMALL_SIZE,&size);
if(size < list_height && size > 0){
? event_num - RESERVE_SMALL_SIZE : 1;
ltt_event_position_set(raw_data->ep, block_num, backward_num);
ltt_tracefile_seek_position(tf, raw_data->ep);
- ev = ltt_tracefile_read(tf);
+ g_assert(ltt_tracefile_read(tf,ev) != NULL);
start = ltt_event_time(ev);
maxNum = RESERVE_SMALL_SIZE_CUBE;
event_viewer_data->current_event_index = 0;
if(first){
raw_data = (RawTraceData*)g_list_nth_data(first,event_number);
if(!raw_data) raw_data = (RawTraceData*)g_list_nth_data(first,0);
- time = ltt_time_sub(raw_data->time, time_span->startTime);
+ time = ltt_time_sub(raw_data->time, time_span.start_time);
event_viewer_data->vadjust_c->value = ltt_time_to_double(time) * NANOSECONDS_PER_SECOND;
g_signal_stop_emission_by_name(G_OBJECT(event_viewer_data->vadjust_c), "value-changed");
event_viewer_data->previous_value = event_viewer_data->vadjust_c->value;
event_viewer_data->last_event = event_viewer_data->end_event_index ;
LAST:
- if(widget)
- gdk_window_set_cursor(win, NULL);
+ return;
+ // if(widget)
+ // gdk_window_set_cursor(win, NULL);
}
-
void add_test_data(EventViewerData *event_viewer_data)
{
}
}
-
+
void
gui_events_free(EventViewerData *event_viewer_data)
{
+ Tab *tab = event_viewer_data->tab;
+
if(event_viewer_data){
- lttv_hooks_remove(event_viewer_data->before_event_hooks,parse_event);
- lttv_hooks_destroy(event_viewer_data->before_event_hooks);
+ lttv_hooks_remove(event_viewer_data->event_hooks,parse_event);
+ lttv_hooks_destroy(event_viewer_data->event_hooks);
remove_all_items_from_queue (event_viewer_data->raw_trace_data_queue);
g_queue_free(event_viewer_data->raw_trace_data_queue);
g_queue_free(event_viewer_data->raw_trace_data_queue_tmp);
- lttvwindow_unregister_time_window_notify(event_viewer_data->mw,
+ lttvwindow_unregister_time_window_notify(tab,
update_time_window, event_viewer_data);
- lttvwindow_unregister_current_time_notify(event_viewer_data->mw,
+ lttvwindow_unregister_current_time_notify(tab,
update_current_time, event_viewer_data);
- lttvwindow_unregister_show_notify(event_viewer_data->mw,
- show_event_detail, event_viewer_data);
- lttvwindow_unregister_traceset_notify(event_viewer_data->mw,
+ //lttvwindow_unregister_show_notify(tab,
+ // show_event_detail, event_viewer_data);
+ lttvwindow_unregister_traceset_notify(tab,
traceset_changed, event_viewer_data);
g_free(event_viewer_data->filter_key);
//if there are hooks for tracefile, add them here
// lttv_tracefile_context_add_hooks(tfc, NULL,NULL,NULL,NULL,
- // event_viewer_data->before_event_hooks,NULL);
+ // event_viewer_data->event_hooks,NULL);
nb_facility = ltt_trace_facility_number(trace);
n = 0;
if(selected){
id = (gint) ltt_eventtype_id(et);
lttv_tracefile_context_add_hooks_by_id(tfc,id,
- event_viewer_data->before_event_hooks,
- NULL);
+ event_viewer_data->event_hooks);
}
n++;
}
//add hooks for process_traceset
// lttv_traceset_context_add_hooks(tsc, NULL, NULL, NULL, NULL, NULL, NULL,
- // NULL, NULL, NULL,event_viewer_data->before_event_hooks,NULL);
+ // NULL, NULL, NULL,event_viewer_data->event_hooks,NULL);
}
//if there are hooks for tracefile, remove them here
// lttv_tracefile_context_remove_hooks(tfc, NULL,NULL,NULL,NULL,
- // event_viewer_data->before_event_hooks,NULL);
+ // event_viewer_data->event_hooks,NULL);
nb_facility = ltt_trace_facility_number(trace);
n = 0;
}
//remove hooks from context
// lttv_traceset_context_remove_hooks(tsc, NULL, NULL, NULL, NULL, NULL, NULL,
- // NULL, NULL, NULL,event_viewer_data->before_event_hooks,NULL);
+ // NULL, NULL, NULL,event_viewer_data->event_hooks,NULL);
}
{
EventViewerData *event_viewer_data = (EventViewerData*) hook_data;
const TimeWindowNotifyData *time_window_notify_data;
- LttvTracesetContext * tsc = lttvwindow_get_traceset_context(event_viewer_data->mw);
+ LttvTracesetContext * tsc = lttvwindow_get_traceset_context(event_viewer_data->tab);
if(event_viewer_data->shown == FALSE){
//event_viewer_data->time_window = *(TimeWindow*)call_data;
- add_context_hooks(event_viewer_data, tsc);
+ //add_context_hooks(event_viewer_data, tsc);
}
return FALSE;
char str_path[64];
int i, j;
LttTime t;
- const TimeInterval *time_span =
- lttvwindow_get_time_span(event_viewer_data->mw);
+ LttvTracesetContext * tsc =
+ lttvwindow_get_traceset_context(event_viewer_data->tab);
+ TimeInterval time_span = tsc->time_span;
if(!event_viewer_data->raw_trace_data_queue->head) return FALSE;
j = count;
count = 0;
}
- t = ltt_time_sub(data->time, time_span->startTime);
+ t = ltt_time_sub(data->time, time_span.start_time);
event_viewer_data->vadjust_c->value = ltt_time_to_double(t) * NANOSECONDS_PER_SECOND;
g_signal_stop_emission_by_name(G_OBJECT(event_viewer_data->vadjust_c), "value-changed");
event_viewer_data->previous_value = event_viewer_data->vadjust_c->value;
insert_data_into_model(event_viewer_data,j, j+event_viewer_data->num_visible_events);
}else{//the event is not in the buffer
- LttTime start = ltt_time_sub(*current_time, time_span->startTime);
+ LttTime start = ltt_time_sub(*current_time, time_span.start_time);
double position = ltt_time_to_double(start) * NANOSECONDS_PER_SECOND;
gtk_adjustment_set_value(event_viewer_data->vadjust_c, position);
}
gboolean traceset_changed(void * hook_data, void * call_data)
{
EventViewerData *event_viewer_data = (EventViewerData*) hook_data;
- const TimeInterval *time_span =
- lttvwindow_get_time_span(event_viewer_data->mw);
+ LttvTracesetContext * tsc =
+ lttvwindow_get_traceset_context(event_viewer_data->tab);
+ TimeInterval time_span = tsc->time_span;
+
LttTime start;
remove_all_items_from_queue(event_viewer_data->raw_trace_data_queue);
gtk_list_store_clear(event_viewer_data->store_m);
event_viewer_data->shown = FALSE;
event_viewer_data->append = TRUE;
- start = ltt_time_sub(time_span->endTime, time_span->startTime);
+ start = ltt_time_sub(time_span.end_time, time_span.start_time);
event_viewer_data->vadjust_c->upper = ltt_time_to_double(start) * NANOSECONDS_PER_SECOND;
// event_viewer_data->vadjust_c->value = 0;
void tree_v_grab_focus(GtkWidget *widget, gpointer data){
EventViewerData *event_viewer_data = (EventViewerData *)data;
- MainWindow * mw = event_viewer_data->mw;
- lttvwindow_report_focus(mw, event_viewer_data->hbox_v);
+ Tab * tab = event_viewer_data->tab;
+ lttvwindow_report_focus(tab, event_viewer_data->hbox_v);
}
void update_raw_data_array(EventViewerData* event_viewer_data, unsigned size)
void get_events(EventViewerData* event_viewer_data, LttTime start,
LttTime end,unsigned max_num_events, unsigned * real_num_events)
{
+ LttvTracesetContext * tsc = lttvwindow_get_traceset_context(event_viewer_data->tab);
+ Tab *tab = event_viewer_data->tab;
+
+ //add_context_hooks(event_viewer_data,tsc);
+ //seek state because we use the main window's traceset context.
+ lttv_state_traceset_seek_time_closest(LTTV_TRACESET_STATE(tsc), start);
+ lttv_process_traceset_middle(tsc, start, G_MAXUINT, NULL);
+ lttv_process_traceset_begin(tsc,
+ NULL,
+ NULL,
+ NULL,
+ event_viewer_data->event_hooks,
+ NULL);
+
+ lttv_process_traceset_middle(tsc, ltt_time_infinite, max_num_events, NULL);
+
+ //remove_context_hooks(event_viewer_data,tsc);
+ lttv_process_traceset_end(tsc,
+ NULL,
+ NULL,
+ NULL,
+ event_viewer_data->event_hooks,
+ NULL);
int size;
- LttvTracesetContext * tsc = lttvwindow_get_traceset_context(event_viewer_data->mw);
-
- add_context_hooks(event_viewer_data,tsc);
- lttv_process_traceset_seek_time(tsc, start);
- lttv_process_traceset(tsc, end, max_num_events);
+ size = event_viewer_data->raw_trace_data_queue_tmp->length;
+ *real_num_events = size;
+
+ update_raw_data_array(event_viewer_data,size);
- remove_context_hooks(event_viewer_data,tsc);
+#if 0
+ EventsRequest *events_request = g_new(EventsRequest, 1);
+ // Create the hooks
+ LttvHooks *event = lttv_hooks_new();
+ LttvHooks *after_request = lttv_hooks_new();
+
+ lttv_hooks_add(after_request,
+ after_get_events,
+ events_request,
+ LTTV_PRIO_DEFAULT);
+ lttv_hooks_add(event,
+ parse_event,
+ event_viewer_data,
+ LTTV_PRIO_DEFAULT);
+
+ // Fill the events request
+ events_request->owner = event_viewer_data;
+ events_request->viewer_data = event_viewer_data;
+ events_request->servicing = FALSE;
+ events_request->start_time = start;
+ events_request->start_position = NULL;
+ events_request->stop_flag = FALSE;
+ events_request->end_time = ltt_time_infinite;
+ events_request->num_events = max_num_events;
+ events_request->end_position = NULL;
+ events_request->before_chunk_traceset = NULL;
+ events_request->before_chunk_trace = NULL;
+ events_request->before_chunk_tracefile = NULL;
+ events_request->event = event;
+ events_request->event_by_id = NULL;
+ events_request->after_chunk_tracefile = NULL;
+ events_request->after_chunk_trace = NULL;
+ events_request->after_chunk_traceset = NULL;
+ events_request->before_request = NULL;
+ events_request->after_request = after_request;
+
+ g_debug("req : start : %u, %u", start.tv_sec,
+ start.tv_nsec);
+
+ lttvwindow_events_request_remove_all(tab,
+ event_viewer_data);
+ lttvwindow_events_request(tab, events_request);
+#endif //0
+}
+#if 0
+int after_get_events(void *hook_data, void *call_data)
+{
+ EventViewerData *event_viewer_data = (EventViewerData *)hook_data;
+ int size;
size = event_viewer_data->raw_trace_data_queue_tmp->length;
*real_num_events = size;
update_raw_data_array(event_viewer_data,size);
}
+#endif //0
static void get_event_detail(LttEvent *e, LttField *f, GString * s)
{
*/
static void init() {
- /* Register the toolbar insert button */
- lttvwindow_register_toolbar(hGuiEventsInsert_xpm, "Insert Event Viewer", h_gui_events);
-
- /* Register the menu item insert entry */
- lttvwindow_register_menu("/", "Insert Event Viewer", h_gui_events);
-
+ lttvwindow_register_constructor("/",
+ "Insert Event Viewer",
+ hGuiEventsInsert_xpm,
+ "Insert Event Viewer",
+ h_gui_events);
}
void event_destroy_walk(gpointer data, gpointer user_data)
EventViewerData *event_viewer_data;
- if(g_event_viewer_data_list){
- g_slist_foreach(g_event_viewer_data_list, event_destroy_walk, NULL );
- g_slist_free(g_event_viewer_data_list);
- }
+ g_slist_foreach(g_event_viewer_data_list, event_destroy_walk, NULL );
+ g_slist_free(g_event_viewer_data_list);
- /* Unregister the toolbar insert button */
- lttvwindow_unregister_toolbar(h_gui_events);
+ lttvwindow_unregister_constructor(h_gui_events);
- /* Unregister the menu item insert entry */
- lttvwindow_unregister_menu(h_gui_events);
}
+++ /dev/null
-/* gtkrbtree.h
- * Copyright (C) 2000 Red Hat, Inc., Jonathan Blandford <jrb@redhat.com>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Library General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Library General Public License for more details.
- *
- * You should have received a copy of the GNU Library General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-/* A Red-Black Tree implementation used specifically by GtkTreeView.
- */
-#ifndef __GTK_RBTREE_H__
-#define __GTK_RBTREE_H__
-
-#ifdef __cplusplus
-extern "C" {
-#endif /* __cplusplus */
-
-#include <glib.h>
-typedef enum
-{
- GTK_RBNODE_BLACK = 1 << 0,
- GTK_RBNODE_RED = 1 << 1,
- GTK_RBNODE_IS_PARENT = 1 << 2,
- GTK_RBNODE_IS_SELECTED = 1 << 3,
- GTK_RBNODE_IS_PRELIT = 1 << 4,
- GTK_RBNODE_IS_SEMI_COLLAPSED = 1 << 5,
- GTK_RBNODE_IS_SEMI_EXPANDED = 1 << 6,
- GTK_RBNODE_INVALID = 1 << 7,
- GTK_RBNODE_COLUMN_INVALID = 1 << 8,
- GTK_RBNODE_DESCENDANTS_INVALID = 1 << 9,
- GTK_RBNODE_NON_COLORS = GTK_RBNODE_IS_PARENT |
- GTK_RBNODE_IS_SELECTED |
- GTK_RBNODE_IS_PRELIT |
- GTK_RBNODE_IS_SEMI_COLLAPSED |
- GTK_RBNODE_IS_SEMI_EXPANDED |
- GTK_RBNODE_INVALID |
- GTK_RBNODE_COLUMN_INVALID |
- GTK_RBNODE_DESCENDANTS_INVALID
-} GtkRBNodeColor;
-
-typedef struct _GtkRBTree GtkRBTree;
-typedef struct _GtkRBNode GtkRBNode;
-typedef struct _GtkRBTreeView GtkRBTreeView;
-
-typedef void (*GtkRBTreeTraverseFunc) (GtkRBTree *tree,
- GtkRBNode *node,
- gpointer data);
-
-struct _GtkRBTree
-{
- GtkRBNode *root;
- GtkRBNode *nil;
- GtkRBTree *parent_tree;
- GtkRBNode *parent_node;
-};
-
-struct _GtkRBNode
-{
- guint flags : 14;
-
- /* We keep track of whether the aggregate count of children plus 1
- * for the node itself comes to an even number. The parity flag is
- * the total count of children mod 2, where the total count of
- * children gets computed in the same way that the total offset gets
- * computed. i.e. not the same as the "count" field below which
- * doesn't include children. We could replace parity with a
- * full-size int field here, and then take % 2 to get the parity flag,
- * but that would use extra memory.
- */
-
- guint parity : 1;
-
- GtkRBNode *left;
- GtkRBNode *right;
- GtkRBNode *parent;
-
- /* count is the number of nodes beneath us, plus 1 for ourselves.
- * i.e. node->left->count + node->right->count + 1
- */
- gint count;
-
- /* this is the total of sizes of
- * node->left, node->right, our own height, and the height
- * of all trees in ->children, iff children exists because
- * the thing is expanded.
- */
- gint offset;
-
- /* Child trees */
- GtkRBTree *children;
-};
-
-
-#define GTK_RBNODE_GET_COLOR(node) (node?(((node->flags>K_RBNODE_RED)==GTK_RBNODE_RED)?GTK_RBNODE_RED:GTK_RBNODE_BLACK):GTK_RBNODE_BLACK)
-#define GTK_RBNODE_SET_COLOR(node,color) if((node->flags&color)!=color)node->flags=node->flags^(GTK_RBNODE_RED|GTK_RBNODE_BLACK)
-#define GTK_RBNODE_GET_HEIGHT(node) (node->offset-(node->left->offset+node->right->offset+(node->children?node->children->root->offset:0)))
-#define GTK_RBNODE_SET_FLAG(node, flag) G_STMT_START{ (node->flags|=flag); }G_STMT_END
-#define GTK_RBNODE_UNSET_FLAG(node, flag) G_STMT_START{ (node->flags&=~(flag)); }G_STMT_END
-#define GTK_RBNODE_FLAG_SET(node, flag) (node?(((node->flags&flag)==flag)?TRUE:FALSE):FALSE)
-
-
-void _gtk_rbtree_push_allocator (GAllocator *allocator);
-void _gtk_rbtree_pop_allocator (void);
-GtkRBTree *_gtk_rbtree_new (void);
-void _gtk_rbtree_free (GtkRBTree *tree);
-void _gtk_rbtree_remove (GtkRBTree *tree);
-void _gtk_rbtree_destroy (GtkRBTree *tree);
-GtkRBNode *_gtk_rbtree_insert_before (GtkRBTree *tree,
- GtkRBNode *node,
- gint height,
- gboolean valid);
-GtkRBNode *_gtk_rbtree_insert_after (GtkRBTree *tree,
- GtkRBNode *node,
- gint height,
- gboolean valid);
-void _gtk_rbtree_remove_node (GtkRBTree *tree,
- GtkRBNode *node);
-void _gtk_rbtree_reorder (GtkRBTree *tree,
- gint *new_order,
- gint length);
-GtkRBNode *_gtk_rbtree_find_count (GtkRBTree *tree,
- gint count);
-void _gtk_rbtree_node_set_height (GtkRBTree *tree,
- GtkRBNode *node,
- gint height);
-void _gtk_rbtree_node_mark_invalid(GtkRBTree *tree,
- GtkRBNode *node);
-void _gtk_rbtree_node_mark_valid (GtkRBTree *tree,
- GtkRBNode *node);
-void _gtk_rbtree_column_invalid (GtkRBTree *tree);
-void _gtk_rbtree_mark_invalid (GtkRBTree *tree);
-void _gtk_rbtree_set_fixed_height (GtkRBTree *tree,
- gint height);
-gint _gtk_rbtree_node_find_offset (GtkRBTree *tree,
- GtkRBNode *node);
-gint _gtk_rbtree_node_find_parity (GtkRBTree *tree,
- GtkRBNode *node);
-gint _gtk_rbtree_find_offset (GtkRBTree *tree,
- gint offset,
- GtkRBTree **new_tree,
- GtkRBNode **new_node);
-void _gtk_rbtree_traverse (GtkRBTree *tree,
- GtkRBNode *node,
- GTraverseType order,
- GtkRBTreeTraverseFunc func,
- gpointer data);
-GtkRBNode *_gtk_rbtree_next (GtkRBTree *tree,
- GtkRBNode *node);
-GtkRBNode *_gtk_rbtree_prev (GtkRBTree *tree,
- GtkRBNode *node);
-void _gtk_rbtree_next_full (GtkRBTree *tree,
- GtkRBNode *node,
- GtkRBTree **new_tree,
- GtkRBNode **new_node);
-void _gtk_rbtree_prev_full (GtkRBTree *tree,
- GtkRBNode *node,
- GtkRBTree **new_tree,
- GtkRBNode **new_node);
-
-gint _gtk_rbtree_get_depth (GtkRBTree *tree);
-
-/* This func checks the integrity of the tree */
-#ifdef G_ENABLE_DEBUG
-void _gtk_rbtree_test (const gchar *where,
- GtkRBTree *tree);
-void _gtk_rbtree_debug_spew (GtkRBTree *tree);
-#endif
-
-#ifdef __cplusplus
-}
-#endif /* __cplusplus */
-
-#endif /* __GTK_RBTREE_H__ */
+++ /dev/null
-/* gtktreeprivate.h
- * Copyright (C) 2000 Red Hat, Inc., Jonathan Blandford <jrb@redhat.com>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Library General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Library General Public License for more details.
- *
- * You should have received a copy of the GNU Library General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
- * Boston, MA 02111-1307, USA.
- */
-
-#ifndef __GTK_TREE_PRIVATE_H__
-#define __GTK_TREE_PRIVATE_H__
-
-
-#ifdef __cplusplus
-extern "C" {
-#endif /* __cplusplus */
-
-#include <gtk/gtktreeview.h>
-#include <gtk/gtktreeselection.h>
-//#include <gtk/gtkrbtree.h>
-#include "gtkrbtree.h"
-
-#define TREE_VIEW_DRAG_WIDTH 6
-
-typedef enum
-{
- GTK_TREE_VIEW_IS_LIST = 1 << 0,
- GTK_TREE_VIEW_SHOW_EXPANDERS = 1 << 1,
- GTK_TREE_VIEW_IN_COLUMN_RESIZE = 1 << 2,
- GTK_TREE_VIEW_ARROW_PRELIT = 1 << 3,
- GTK_TREE_VIEW_HEADERS_VISIBLE = 1 << 4,
- GTK_TREE_VIEW_DRAW_KEYFOCUS = 1 << 5,
- GTK_TREE_VIEW_MODEL_SETUP = 1 << 6,
- GTK_TREE_VIEW_IN_COLUMN_DRAG = 1 << 7
-} GtkTreeViewFlags;
-
-enum
-{
- DRAG_COLUMN_WINDOW_STATE_UNSET = 0,
- DRAG_COLUMN_WINDOW_STATE_ORIGINAL = 1,
- DRAG_COLUMN_WINDOW_STATE_ARROW = 2,
- DRAG_COLUMN_WINDOW_STATE_ARROW_LEFT = 3,
- DRAG_COLUMN_WINDOW_STATE_ARROW_RIGHT = 4
-};
-
-#define GTK_TREE_VIEW_SET_FLAG(tree_view, flag) G_STMT_START{ (tree_view->priv->flags|=flag); }G_STMT_END
-#define GTK_TREE_VIEW_UNSET_FLAG(tree_view, flag) G_STMT_START{ (tree_view->priv->flags&=~(flag)); }G_STMT_END
-#define GTK_TREE_VIEW_FLAG_SET(tree_view, flag) ((tree_view->priv->flags&flag)==flag)
-#define TREE_VIEW_HEADER_HEIGHT(tree_view) (GTK_TREE_VIEW_FLAG_SET (tree_view, GTK_TREE_VIEW_HEADERS_VISIBLE)?tree_view->priv->header_height:0)
-#define TREE_VIEW_COLUMN_REQUESTED_WIDTH(column) (CLAMP (column->requested_width, (column->min_width!=-1)?column->min_width:column->requested_width, (column->max_width!=-1)?column->max_width:column->requested_width))
-#define TREE_VIEW_DRAW_EXPANDERS(tree_view) (!GTK_TREE_VIEW_FLAG_SET (tree_view, GTK_TREE_VIEW_IS_LIST)&>K_TREE_VIEW_FLAG_SET (tree_view, GTK_TREE_VIEW_SHOW_EXPANDERS))
-
- /* This lovely little value is used to determine how far away from the title bar
- * you can move the mouse and still have a column drag work.
- */
-#define TREE_VIEW_COLUMN_DRAG_DEAD_MULTIPLIER(tree_view) (10*TREE_VIEW_HEADER_HEIGHT(tree_view))
-
-typedef void (*GtkTreeViewSearchDialogPositionFunc) (GtkTreeView *tree_view,
- GtkWidget *search_dialog);
-
-typedef struct _GtkTreeViewColumnReorder GtkTreeViewColumnReorder;
-struct _GtkTreeViewColumnReorder
-{
- gint left_align;
- gint right_align;
- GtkTreeViewColumn *left_column;
- GtkTreeViewColumn *right_column;
-};
-
-struct _GtkTreeViewPrivate
-{
- GtkTreeModel *model;
-
- guint flags;
- /* tree information */
- GtkRBTree *tree;
-
- GtkRBNode *button_pressed_node;
- GtkRBTree *button_pressed_tree;
-
- GList *children;
- gint width;
- gint height;
- gint expander_size;
-
- GtkAdjustment *hadjustment;
- GtkAdjustment *vadjustment;
-
- GdkWindow *bin_window;
- GdkWindow *header_window;
- GdkWindow *drag_window;
- GdkWindow *drag_highlight_window;
- GtkTreeViewColumn *drag_column;
-
- GtkTreeRowReference *last_button_press;
- GtkTreeRowReference *last_button_press_2;
-
- /* bin_window offset */
- GtkTreeRowReference *top_row;
- gint top_row_dy;
- /* dy == y pos of top_row + top_row_dy */
- /* we cache it for simplicity of the code */
- gint dy;
- gint drag_column_x;
-
- GtkTreeViewColumn *expander_column;
- GtkTreeViewColumn *edited_column;
- guint presize_handler_timer;
- guint validate_rows_timer;
- guint scroll_sync_timer;
-
- /* Focus code */
- GtkTreeViewColumn *focus_column;
-
- /* Selection stuff */
- GtkTreeRowReference *anchor;
- GtkTreeRowReference *cursor;
-
- /* Column Resizing */
- gint drag_pos;
- gint x_drag;
-
- /* Prelight information */
- GtkRBNode *prelight_node;
- GtkRBTree *prelight_tree;
-
- /* The node that's currently being collapsed or expanded */
- GtkRBNode *expanded_collapsed_node;
- GtkRBTree *expanded_collapsed_tree;
- guint expand_collapse_timeout;
-
- /* Selection information */
- GtkTreeSelection *selection;
-
- /* Header information */
- gint n_columns;
- GList *columns;
- gint header_height;
-
- GtkTreeViewColumnDropFunc column_drop_func;
- gpointer column_drop_func_data;
- GtkDestroyNotify column_drop_func_data_destroy;
- GList *column_drag_info;
- GtkTreeViewColumnReorder *cur_reorder;
-
- /* ATK Hack */
- GtkTreeDestroyCountFunc destroy_count_func;
- gpointer destroy_count_data;
- GtkDestroyNotify destroy_count_destroy;
-
- /* Scroll timeout (e.g. during dnd) */
- guint scroll_timeout;
-
- /* Row drag-and-drop */
- GtkTreeRowReference *drag_dest_row;
- GtkTreeViewDropPosition drag_dest_pos;
- guint open_dest_timeout;
-
- gint pressed_button;
- gint press_start_x;
- gint press_start_y;
-
- /* Scroll-to functionality when unrealized */
- GtkTreeRowReference *scroll_to_path;
- GtkTreeViewColumn *scroll_to_column;
- gfloat scroll_to_row_align;
- gfloat scroll_to_col_align;
- guint scroll_to_use_align : 1;
-
- guint fixed_height_check : 1;
-
- guint reorderable : 1;
- guint header_has_focus : 1;
- guint drag_column_window_state : 3;
- /* hint to display rows in alternating colors */
- guint has_rules : 1;
- guint mark_rows_col_dirty : 1;
-
- /* interactive search */
- guint enable_search : 1;
- guint disable_popdown : 1;
- gint search_column;
- GtkTreeViewSearchDialogPositionFunc search_dialog_position_func;
- GtkTreeViewSearchEqualFunc search_equal_func;
- gpointer search_user_data;
- GtkDestroyNotify search_destroy;
-};
-
-/* cool ABI compat hack */
-#define GTK_CELL_RENDERER_INFO_KEY "gtk-cell-renderer-info"
-
-typedef struct _GtkCellRendererInfo GtkCellRendererInfo;
-struct _GtkCellRendererInfo
-{
- GdkColor cell_background;
-
- /* text renderer */
- gulong focus_out_id;
-
- /* toggle renderer */
- gboolean inconsistent :1;
-};
-
-#ifdef __GNUC__
-
-#define TREE_VIEW_INTERNAL_ASSERT(expr, ret) G_STMT_START{ \
- if (!(expr)) \
- { \
- g_log (G_LOG_DOMAIN, \
- G_LOG_LEVEL_CRITICAL, \
- "file %s: line %d (%s): assertion `%s' failed.\n" \
- "There is a disparity between the internal view of the GtkTreeView,\n" \
- "and the GtkTreeModel. This generally means that the model has changed\n"\
- "without letting the view know. Any display from now on is likely to\n" \
- "be incorrect.\n", \
- __FILE__, \
- __LINE__, \
- __PRETTY_FUNCTION__, \
- #expr); \
- return ret; \
- }; }G_STMT_END
-
-#define TREE_VIEW_INTERNAL_ASSERT_VOID(expr) G_STMT_START{ \
- if (!(expr)) \
- { \
- g_log (G_LOG_DOMAIN, \
- G_LOG_LEVEL_CRITICAL, \
- "file %s: line %d (%s): assertion `%s' failed.\n" \
- "There is a disparity between the internal view of the GtkTreeView,\n" \
- "and the GtkTreeModel. This generally means that the model has changed\n"\
- "without letting the view know. Any display from now on is likely to\n" \
- "be incorrect.\n", \
- __FILE__, \
- __LINE__, \
- __PRETTY_FUNCTION__, \
- #expr); \
- return; \
- }; }G_STMT_END
-
-#else
-
-#define TREE_VIEW_INTERNAL_ASSERT(expr, ret) G_STMT_START{ \
- if (!(expr)) \
- { \
- g_log (G_LOG_DOMAIN, \
- G_LOG_LEVEL_CRITICAL, \
- "file %s: line %d: assertion `%s' failed.\n" \
- "There is a disparity between the internal view of the GtkTreeView,\n" \
- "and the GtkTreeModel. This generally means that the model has changed\n"\
- "without letting the view know. Any display from now on is likely to\n" \
- "be incorrect.\n", \
- __FILE__, \
- __LINE__, \
- #expr); \
- return ret; \
- }; }G_STMT_END
-
-#define TREE_VIEW_INTERNAL_ASSERT_VOID(expr) G_STMT_START{ \
- if (!(expr)) \
- { \
- g_log (G_LOG_DOMAIN, \
- G_LOG_LEVEL_CRITICAL, \
- "file %s: line %d: assertion '%s' failed.\n" \
- "There is a disparity between the internal view of the GtkTreeView,\n" \
- "and the GtkTreeModel. This generally means that the model has changed\n"\
- "without letting the view know. Any display from now on is likely to\n" \
- "be incorrect.\n", \
- __FILE__, \
- __LINE__, \
- #expr); \
- return; \
- }; }G_STMT_END
-#endif
-
-
-/* functions that shouldn't be exported */
-void _gtk_tree_selection_internal_select_node (GtkTreeSelection *selection,
- GtkRBNode *node,
- GtkRBTree *tree,
- GtkTreePath *path,
- GdkModifierType state,
- gboolean override_browse_mode);
-gboolean _gtk_tree_view_find_node (GtkTreeView *tree_view,
- GtkTreePath *path,
- GtkRBTree **tree,
- GtkRBNode **node);
-GtkTreePath *_gtk_tree_view_find_path (GtkTreeView *tree_view,
- GtkRBTree *tree,
- GtkRBNode *node);
-void _gtk_tree_view_child_move_resize (GtkTreeView *tree_view,
- GtkWidget *widget,
- gint x,
- gint y,
- gint width,
- gint height);
-void _gtk_tree_view_queue_draw_node (GtkTreeView *tree_view,
- GtkRBTree *tree,
- GtkRBNode *node,
- GdkRectangle *clip_rect);
-
-void _gtk_tree_view_column_realize_button (GtkTreeViewColumn *column);
-void _gtk_tree_view_column_unrealize_button (GtkTreeViewColumn *column);
-void _gtk_tree_view_column_set_tree_view (GtkTreeViewColumn *column,
- GtkTreeView *tree_view);
-void _gtk_tree_view_column_unset_model (GtkTreeViewColumn *column,
- GtkTreeModel *old_model);
-void _gtk_tree_view_column_unset_tree_view (GtkTreeViewColumn *column);
-void _gtk_tree_view_column_set_width (GtkTreeViewColumn *column,
- gint width);
-void _gtk_tree_view_column_start_drag (GtkTreeView *tree_view,
- GtkTreeViewColumn *column);
-gboolean _gtk_tree_view_column_cell_event (GtkTreeViewColumn *tree_column,
- GtkCellEditable **editable_widget,
- GdkEvent *event,
- gchar *path_string,
- GdkRectangle *background_area,
- GdkRectangle *cell_area,
- guint flags);
-void _gtk_tree_view_column_start_editing (GtkTreeViewColumn *tree_column,
- GtkCellEditable *editable_widget);
-void _gtk_tree_view_column_stop_editing (GtkTreeViewColumn *tree_column);
-void _gtk_tree_view_install_mark_rows_col_dirty (GtkTreeView *tree_view);
-void _gtk_tree_view_column_autosize (GtkTreeView *tree_view,
- GtkTreeViewColumn *column);
-
-gboolean _gtk_tree_view_column_has_editable_cell (GtkTreeViewColumn *column);
-GtkCellRenderer *_gtk_tree_view_column_get_edited_cell (GtkTreeViewColumn *column);
-gint _gtk_tree_view_column_count_special_cells (GtkTreeViewColumn *column);
-GtkCellRenderer *_gtk_tree_view_column_get_cell_at_pos (GtkTreeViewColumn *column,
- gint x);
-
-GtkTreeSelection* _gtk_tree_selection_new (void);
-GtkTreeSelection* _gtk_tree_selection_new_with_tree_view (GtkTreeView *tree_view);
-void _gtk_tree_selection_set_tree_view (GtkTreeSelection *selection,
- GtkTreeView *tree_view);
-
-void _gtk_tree_view_column_cell_render (GtkTreeViewColumn *tree_column,
- GdkWindow *window,
- GdkRectangle *background_area,
- GdkRectangle *cell_area,
- GdkRectangle *expose_area,
- guint flags);
-gboolean _gtk_tree_view_column_cell_focus (GtkTreeViewColumn *tree_column,
- gint direction,
- gboolean left,
- gboolean right);
-void _gtk_tree_view_column_cell_draw_focus (GtkTreeViewColumn *tree_column,
- GdkWindow *window,
- GdkRectangle *background_area,
- GdkRectangle *cell_area,
- GdkRectangle *expose_area,
- guint flags);
-void _gtk_tree_view_column_cell_set_dirty (GtkTreeViewColumn *tree_column,
- gboolean install_handler);
-void _gtk_tree_view_column_get_neighbor_sizes (GtkTreeViewColumn *column,
- GtkCellRenderer *cell,
- gint *left,
- gint *right);
-
-
-#ifdef __cplusplus
-}
-#endif /* __cplusplus */
-
-
-#endif /* __GTK_TREE_PRIVATE_H__ */
-