pidgin-2.10.11-init-media-optional.patch 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. # HG changeset patch
  2. # User Jakub Adam <jakub.adam@ktknet.cz>
  3. # Date 1407847148 -7200
  4. # Node ID 7767aaeade6404396204794f9bc75d9a2cb723f0
  5. # Parent 8e4fa54f166211ffd6cd869cca611e8d64ea1fdf
  6. media: make "init-media" signal handler optional
  7. Change the logic so that the PurpleMedia instance isn't disposed when
  8. "init-media" has no connected handlers.
  9. We want the media object freed only when some signal callback function
  10. explicitly returns FALSE, indicating an error during the initialization.
  11. This is mostly useful for the imminent addition of private media streams.
  12. diff --git a/libpurple/mediamanager.c b/libpurple/mediamanager.c
  13. --- a/libpurple/mediamanager.c
  14. +++ b/libpurple/mediamanager.c
  15. @@ -334,7 +334,7 @@
  16. {
  17. #ifdef USE_VV
  18. PurpleMedia *media;
  19. - gboolean signal_ret;
  20. + guint signal_id;
  21. media = PURPLE_MEDIA(g_object_new(purple_media_get_type(),
  22. "manager", manager,
  23. @@ -343,12 +343,17 @@
  24. "initiator", initiator,
  25. NULL));
  26. - g_signal_emit(manager, purple_media_manager_signals[INIT_MEDIA], 0,
  27. - media, account, remote_user, &signal_ret);
  28. + signal_id = purple_media_manager_signals[INIT_MEDIA];
  29. - if (signal_ret == FALSE) {
  30. - g_object_unref(media);
  31. - return NULL;
  32. + if (g_signal_has_handler_pending(manager, signal_id, 0, FALSE)) {
  33. + gboolean signal_ret;
  34. +
  35. + g_signal_emit(manager, signal_id, 0, media, account, remote_user,
  36. + &signal_ret);
  37. + if (signal_ret == FALSE) {
  38. + g_object_unref(media);
  39. + return NULL;
  40. + }
  41. }
  42. manager->priv->medias = g_list_append(manager->priv->medias, media);