This source file includes following definitions.
- mc_event_init
- mc_event_deinit
- mc_event_mass_add
- mc_event_present
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27 #include <config.h>
28
29 #include "lib/global.h"
30 #include "lib/util.h"
31 #include "lib/event.h"
32
33 #include "internal.h"
34
35
36
37
38
39
40
41
42
43 GTree *mc_event_grouplist = NULL;
44
45
46
47
48
49
50 gboolean
51 mc_event_init (GError **mcerror)
52 {
53 mc_return_val_if_error (mcerror, FALSE);
54
55 if (mc_event_grouplist != NULL)
56 {
57 mc_propagate_error (mcerror, 0, "%s", _ ("Event system already initialized"));
58 return FALSE;
59 }
60
61 mc_event_grouplist = g_tree_new_full ((GCompareDataFunc) g_ascii_strcasecmp, NULL,
62 (GDestroyNotify) g_free, (GDestroyNotify) g_tree_destroy);
63
64 if (mc_event_grouplist == NULL)
65 {
66 mc_propagate_error (mcerror, 0, "%s", _ ("Failed to initialize event system"));
67 return FALSE;
68 }
69
70 return TRUE;
71 }
72
73
74
75 gboolean
76 mc_event_deinit (GError **mcerror)
77 {
78 mc_return_val_if_error (mcerror, FALSE);
79
80 if (mc_event_grouplist == NULL)
81 {
82 mc_propagate_error (mcerror, 0, "%s", _ ("Event system not initialized"));
83 return FALSE;
84 }
85
86 g_tree_destroy (mc_event_grouplist);
87 mc_event_grouplist = NULL;
88 return TRUE;
89 }
90
91
92
93 gboolean
94 mc_event_mass_add (const event_init_t *events, GError **mcerror)
95 {
96 size_t array_index;
97
98 mc_return_val_if_error (mcerror, FALSE);
99
100 for (array_index = 0; events[array_index].event_group_name != NULL; array_index++)
101 {
102 if (!mc_event_add (events[array_index].event_group_name, events[array_index].event_name,
103 events[array_index].cb, events[array_index].init_data, mcerror))
104 {
105 return FALSE;
106 }
107 }
108 return TRUE;
109 }
110
111
112
113 gboolean
114 mc_event_present (const gchar *event_group_name, const gchar *event_name)
115 {
116 GTree *event_group;
117 GPtrArray *callbacks;
118
119 if (mc_event_grouplist == NULL || event_group_name == NULL || event_name == NULL)
120 return FALSE;
121
122 event_group = mc_event_get_event_group_by_name (event_group_name, FALSE, NULL);
123 if (event_group == NULL)
124 return FALSE;
125
126 callbacks = mc_event_get_event_by_name (event_group, event_name, FALSE, NULL);
127 if (callbacks == NULL)
128 return FALSE;
129
130 return TRUE;
131 }
132
133