+/*! \defgroup guiEvents libguiEvents: The GUI Events display plugin */
+/*\@{*/
+
+/*! \file guiEvents.c
+ * \brief Graphical plugin for showing events.
+ *
+ * This plugin adds a Events Viewer functionnality to Linux TraceToolkit
+ * GUI when this plugin is loaded. The init and destroy functions add the
+ * viewer's insertion menu item and toolbar icon by calling gtkTraceSet's
+ * API functions. Then, when a viewer's object is created, the constructor
+ * creates ans register through API functions what is needed to interact
+ * with the TraceSet window.
+ *
+ * This plugin uses the gdk library to draw the events and gtk to interact
+ * with the user.
+ *
+ * Author : Mathieu Desnoyers, June 2003
+ */
+
+#include <glib.h>
+#include <gmodule.h>
+#include <gtk.h>
+#include <gdk.h>
+
+#include <lttv/module.h>
+
+#include "guiEvents.h"
+#include "icons/guiEventsInsert.xpm"
+
+//! Event Viewer's constructor
+GtkWidget *guiEvents(GtkWidget *ParentWindow);
+
+//! Callback functions
+gboolean
+expose_event_callback (GtkWidget *widget, GdkEventExpose *event, gpointer data);
+
+/**
+ * plugin's init function
+ *
+ * This function initializes the Event Viewer functionnality through the
+ * gtkTraceSet API.
+ */
+G_MODULE_EXPORT void init() {
+ g_critical("GUI Event Viewer init()");
+
+ /* Register the toolbar insert button */
+ ToolbarItemReg(guiEventsInsert_xpm, "Insert Event Viewer", guiEvent);
+
+ /* Register the menu item insert entry */
+ MenuItemReg("/", "Insert Event Viewer", guiEvent);
+
+}
+
+/**
+ * plugin's destroy function
+ *
+ * This function releases the memory reserved by the module and unregisters
+ * everything that has been registered in the gtkTraceSet API.
+ */
+G_MODULE_EXPORT void destroy() {
+ g_critical("GUI Event Viewer destroy()");
+
+ /* Unregister the toolbar insert button */
+ ToolbarItemUnreg(guiEvent);
+
+ /* Unregister the menu item insert entry */
+ MenuItemUnreg(guiEvents);
+}
+
+/**
+ * Event Viewer's constructor
+ *
+ * This constructor is given as a parameter to the menuitem and toolbar button
+ * registration. It creates the drawing widget.
+ * @param ParentWindow A pointer to the parent window.
+ * @return The widget created.
+ */
+static GtkWidget *
+guiEvents(GtkWidget *ParentWindow)
+{
+ GtkWidget *drawing_area = gtk_drawing_area_new ();
+
+ g_signal_connect (G_OBJECT (drawing_area), "expose_event",
+ G_CALLBACK (expose_event_callback), NULL);
+}
+
+
+gboolean
+expose_event_callback (GtkWidget *widget, GdkEventExpose *event, gpointer data)
+{
+
+
+}
+
+
+/*\@}*/