manage.c 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. /*
  2. Handle any events in application.
  3. Manage events: add, delete, destroy, search
  4. Copyright (C) 2011 The Free Software Foundation, Inc.
  5. Written by:
  6. Slava Zanko <slavazanko@gmail.com>, 2011.
  7. This file is part of the Midnight Commander.
  8. The Midnight Commander is free software; you can redistribute it
  9. and/or modify it under the terms of the GNU General Public License as
  10. published by the Free Software Foundation; either version 2 of the
  11. License, or (at your option) any later version.
  12. The Midnight Commander is distributed in the hope that it will be
  13. useful, but WITHOUT ANY WARRANTY; without even the implied warranty
  14. of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. General Public License for more details.
  16. You should have received a copy of the GNU General Public License
  17. along with this program; if not, write to the Free Software
  18. Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
  19. MA 02110-1301, USA.
  20. */
  21. #include <config.h>
  22. #include "lib/global.h"
  23. #include "lib/event.h"
  24. #include "internal.h"
  25. /*** global variables ****************************************************************************/
  26. /*** file scope macro definitions ****************************************************************/
  27. /*** file scope type declarations ****************************************************************/
  28. /*** file scope variables ************************************************************************/
  29. /*** file scope functions ************************************************************************/
  30. /* --------------------------------------------------------------------------------------------- */
  31. static void
  32. mc_event_group_destroy_value (gpointer data)
  33. {
  34. GPtrArray *callbacks;
  35. callbacks = (GPtrArray *) data;
  36. g_ptr_array_foreach (callbacks, (GFunc) g_free, NULL);
  37. g_ptr_array_free (callbacks, TRUE);
  38. }
  39. /* --------------------------------------------------------------------------------------------- */
  40. /* --------------------------------------------------------------------------------------------- */
  41. /*** public functions ****************************************************************************/
  42. /* --------------------------------------------------------------------------------------------- */
  43. gboolean
  44. mc_event_add (const gchar * event_group_name, const gchar * event_name,
  45. mc_event_callback_func_t event_callback, gpointer event_init_data, GError ** mcerror)
  46. {
  47. GTree *event_group;
  48. GPtrArray *callbacks;
  49. mc_event_callback_t *cb;
  50. if (mc_event_grouplist == NULL || event_group_name == NULL || event_name == NULL
  51. || event_callback == NULL)
  52. {
  53. g_propagate_error (mcerror,
  54. g_error_new (MC_ERROR, 1,
  55. _("Check input data! Some of parameters are NULL!")));
  56. return FALSE;
  57. }
  58. event_group = mc_event_get_event_group_by_name (event_group_name, TRUE, mcerror);
  59. if (event_group == NULL)
  60. return FALSE;
  61. callbacks = mc_event_get_event_by_name (event_group, event_name, TRUE, mcerror);
  62. if (callbacks == NULL)
  63. return FALSE;
  64. cb = mc_event_is_callback_in_array (callbacks, event_callback, event_init_data);
  65. if (cb == NULL)
  66. {
  67. cb = g_new0 (mc_event_callback_t, 1);
  68. cb->callback = event_callback;
  69. g_ptr_array_add (callbacks, (gpointer) cb);
  70. }
  71. cb->init_data = event_init_data;
  72. return TRUE;
  73. }
  74. /* --------------------------------------------------------------------------------------------- */
  75. void
  76. mc_event_del (const gchar * event_group_name, const gchar * event_name,
  77. mc_event_callback_func_t event_callback, gpointer event_init_data)
  78. {
  79. GTree *event_group;
  80. GPtrArray *callbacks;
  81. mc_event_callback_t *cb;
  82. if (mc_event_grouplist == NULL || event_group_name == NULL || event_name == NULL
  83. || event_callback == NULL)
  84. return;
  85. event_group = mc_event_get_event_group_by_name (event_group_name, FALSE, NULL);
  86. if (event_group == NULL)
  87. return;
  88. callbacks = mc_event_get_event_by_name (event_group, event_name, FALSE, NULL);
  89. if (callbacks == NULL)
  90. return;
  91. cb = mc_event_is_callback_in_array (callbacks, event_callback, event_init_data);
  92. if (cb == NULL)
  93. return;
  94. g_ptr_array_remove (callbacks, (gpointer) cb);
  95. g_free ((gpointer) cb);
  96. }
  97. /* --------------------------------------------------------------------------------------------- */
  98. void
  99. mc_event_destroy (const gchar * event_group_name, const gchar * event_name)
  100. {
  101. GTree *event_group;
  102. if (mc_event_grouplist == NULL || event_group_name == NULL || event_name == NULL)
  103. return;
  104. event_group = mc_event_get_event_group_by_name (event_group_name, FALSE, NULL);
  105. g_tree_remove (event_group, (gconstpointer) event_name);
  106. }
  107. /* --------------------------------------------------------------------------------------------- */
  108. void
  109. mc_event_group_del (const gchar * event_group_name)
  110. {
  111. if (mc_event_grouplist != NULL && event_group_name != NULL)
  112. g_tree_remove (mc_event_grouplist, (gconstpointer) event_group_name);
  113. }
  114. /* --------------------------------------------------------------------------------------------- */
  115. GTree *
  116. mc_event_get_event_group_by_name (const gchar * event_group_name, gboolean create_new,
  117. GError ** mcerror)
  118. {
  119. GTree *event_group;
  120. event_group = (GTree *) g_tree_lookup (mc_event_grouplist, (gconstpointer) event_group_name);
  121. if (event_group == NULL && create_new)
  122. {
  123. event_group =
  124. g_tree_new_full ((GCompareDataFunc) g_ascii_strcasecmp,
  125. NULL,
  126. (GDestroyNotify) g_free,
  127. (GDestroyNotify) mc_event_group_destroy_value);
  128. if (event_group == NULL)
  129. {
  130. g_propagate_error (mcerror,
  131. g_error_new (MC_ERROR, 1,
  132. _("Unable to create group '%s' for events!"),
  133. event_group_name));
  134. return NULL;
  135. }
  136. g_tree_insert (mc_event_grouplist, g_strdup (event_group_name), (gpointer) event_group);
  137. }
  138. return event_group;
  139. }
  140. /* --------------------------------------------------------------------------------------------- */
  141. GPtrArray *
  142. mc_event_get_event_by_name (GTree * event_group, const gchar * event_name, gboolean create_new,
  143. GError ** mcerror)
  144. {
  145. GPtrArray *callbacks;
  146. callbacks = (GPtrArray *) g_tree_lookup (event_group, (gconstpointer) event_name);
  147. if (callbacks == NULL && create_new)
  148. {
  149. callbacks = g_ptr_array_new ();
  150. if (callbacks == NULL)
  151. {
  152. g_propagate_error (mcerror,
  153. g_error_new (MC_ERROR, 1,
  154. _("Unable to create event '%s'!"), event_name));
  155. return NULL;
  156. }
  157. g_tree_insert (event_group, g_strdup (event_name), (gpointer) callbacks);
  158. }
  159. return callbacks;
  160. }
  161. /* --------------------------------------------------------------------------------------------- */
  162. mc_event_callback_t *
  163. mc_event_is_callback_in_array (GPtrArray * callbacks, mc_event_callback_func_t event_callback, gpointer event_init_data)
  164. {
  165. guint array_index;
  166. for (array_index = 0; array_index < callbacks->len; array_index++)
  167. {
  168. mc_event_callback_t *cb = g_ptr_array_index (callbacks, array_index);
  169. if (cb->callback == event_callback && cb->init_data == event_init_data)
  170. return cb;
  171. }
  172. return NULL;
  173. }
  174. /* --------------------------------------------------------------------------------------------- */