Update FSF address
[lttv.git] / lttv / modules / gui / controlflow / module.c
1 /* This file is part of the Linux Trace Toolkit viewer
2 * Copyright (C) 2003-2004 Mathieu Desnoyers
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., 51 Franklin Street, Fifth Floor, Boston,
16 * MA 02110-1301, USA.
17 */
18
19
20
21 /*! \defgroup guiEvents libguiControlFlow: The GUI ControlFlow display plugin */
22 /*\@{*/
23
24 /*! \file guiControlFlow.c
25 * \brief Graphical plugin for showing control flow of a trace.
26 *
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.
33 *
34 * This plugin uses the gdk library to draw the events and gtk to interact
35 * with the user.
36 *
37 * Author : Mathieu Desnoyers, June 2003
38 */
39
40 #ifdef HAVE_CONFIG_H
41 #include <config.h>
42 #endif
43
44 #include <glib.h>
45 #include <lttv/lttv.h>
46 #include <lttv/module.h>
47 #include <lttvwindow/lttvwindow.h>
48
49 #include "cfv.h"
50 #include "lttv_plugin_cfv.h"
51 #include "eventhooks.h"
52
53 #include "hGuiControlFlowInsert.xpm"
54
55 GQuark LTT_NAME_CPU;
56
57 /** Array containing instanced objects. Used when module is unloaded */
58 GSList *g_control_flow_data_list = NULL ;
59
60 /*****************************************************************************
61 * Functions for module loading/unloading *
62 *****************************************************************************/
63 /**
64 * plugin's init function
65 *
66 * This function initializes the Control Flow Viewer functionnality through the
67 * gtkTraceSet API.
68 */
69 static void init() {
70
71 g_info("GUI ControlFlow Viewer init()");
72
73 /* Register the toolbar insert button and menu entry*/
74 lttvwindow_register_constructor("guicontrolflow",
75 "/",
76 "Insert Control Flow Viewer",
77 hGuiControlFlowInsert_xpm,
78 "Insert Control Flow Viewer",
79 h_guicontrolflow);
80
81 LTT_NAME_CPU = g_quark_from_string("/cpu");
82 }
83
84 void destroy_walk(gpointer data, gpointer user_data)
85 {
86 g_info("Walk destroy GUI Control Flow Viewer");
87 guicontrolflow_destructor_full((LttvPluginCFV*)data);
88 }
89
90
91 /**
92 * plugin's destroy function
93 *
94 * This function releases the memory reserved by the module and unregisters
95 * everything that has been registered in the gtkTraceSet API.
96 */
97 static void destroy() {
98 g_info("GUI Control Flow Viewer destroy()");
99
100 g_slist_foreach(g_control_flow_data_list, destroy_walk, NULL );
101
102 g_slist_free(g_control_flow_data_list);
103
104 g_slist_free(g_control_flow_data_list);
105
106 /* Unregister the toolbar insert button and menu entry */
107 lttvwindow_unregister_constructor(h_guicontrolflow);
108 }
109
110
111 LTTV_MODULE("guicontrolflow", "Control flow viewer", \
112 "Graphical module to view processes state and control flow", \
113 init, destroy, "lttvwindow")
This page took 0.031316 seconds and 4 git commands to generate.