1 /* This file is part of the Linux Trace Toolkit viewer
2 * Copyright (C) 2003-2004 Mathieu Desnoyers
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;
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.
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,
21 /*! \defgroup guiEvents libguiControlFlow: The GUI ControlFlow display plugin */
24 /*! \file guiControlFlow.c
25 * \brief Graphical plugin for showing control flow of a trace.
27 * This plugin adds a Control Flow Viewer functionnality to Linux TraceToolkit
28 * GUI when this plugin is loaded. The init and destroy functions add the
29 * viewer's insertion menu item and toolbar icon by calling viewer.h's
30 * API functions. Then, when a viewer's object is created, the constructor
31 * creates ans register through API functions what is needed to interact
32 * with the TraceSet window.
34 * This plugin uses the gdk library to draw the events and gtk to interact
37 * Author : Mathieu Desnoyers, June 2003
45 #include <lttv/lttv.h>
46 #include <lttv/module.h>
47 #include <lttvwindow/lttvwindow.h>
50 #include "lttv_plugin_cfv.h"
51 #include "eventhooks.h"
53 #include "hGuiControlFlowInsert.xpm"
54 #include "hGuiXenoLTTInsert.xpm"
55 #include "hLegendInsert.xpm"
59 /** Array containing instanced objects. Used when module is unloaded */
60 GSList
*g_control_flow_data_list
= NULL
;
62 GSList
*g_legend_list
= NULL
;
64 /*****************************************************************************
65 * Functions for module loading/unloading *
66 *****************************************************************************/
68 * plugin's init function
70 * This function initializes the Control Flow Viewer functionnality through the
75 g_info("GUI ControlFlow Viewer init()");
77 /* Register the toolbar insert button and menu entry*/
78 lttvwindow_register_constructor("guicontrolflow",
80 "Insert Control Flow Viewer",
81 hGuiControlFlowInsert_xpm
,
82 "Insert Control Flow Viewer",
85 lttvwindow_register_constructor("guicontrolflowlegend",
87 "Popup Control Flow Viewer Legend",
89 "Popup Control Flow Viewer Legend",
93 LTT_NAME_CPU
= g_quark_from_string("/cpu");
96 void destroy_walk(gpointer data
, gpointer user_data
)
98 g_info("Walk destroy GUI Control Flow Viewer");
99 guicontrolflow_destructor_full((LttvPluginCFV
*)data
);
102 void destroy_legend_walk(gpointer data
, gpointer user_data
)
104 g_info("Walk destroy GUI Control Flow Viewer");
105 legend_destructor((GtkWindow
*)data
);
111 * plugin's destroy function
113 * This function releases the memory reserved by the module and unregisters
114 * everything that has been registered in the gtkTraceSet API.
116 static void destroy() {
117 g_info("GUI Control Flow Viewer destroy()");
119 g_slist_foreach(g_control_flow_data_list
, destroy_walk
, NULL
);
121 g_slist_free(g_control_flow_data_list
);
123 g_slist_foreach(g_legend_list
, destroy_legend_walk
, NULL
);
125 g_slist_free(g_control_flow_data_list
);
127 /* Unregister the toolbar insert button and menu entry */
128 lttvwindow_unregister_constructor(h_guicontrolflow
);
129 lttvwindow_unregister_constructor(h_legend
);
133 LTTV_MODULE("guicontrolflow", "Control flow viewer", \
134 "Graphical module to view processes state and control flow", \
135 init
, destroy
, "lttvwindow")