aboutsummaryrefslogtreecommitdiffstats
path: root/libempathy/empathy-message.c
diff options
context:
space:
mode:
authorEmilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk>2011-04-28 00:57:59 +0800
committerEmilio Pozuelo Monfort <emilio.pozuelo@collabora.co.uk>2011-04-28 00:57:59 +0800
commit92172bae28e5fa2a91d87bc9e715c9bad01d888f (patch)
tree5ab52ee86f040652b5caa29bae94455b3ee51221 /libempathy/empathy-message.c
parent2430f28d4659fdfc428b0bdf89d774b0c7b9cdc6 (diff)
parent474cd4639af3a45919b69ae4a3cc637c376e90bd (diff)
downloadgsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.tar
gsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.tar.gz
gsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.tar.bz2
gsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.tar.lz
gsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.tar.xz
gsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.tar.zst
gsoc2013-empathy-92172bae28e5fa2a91d87bc9e715c9bad01d888f.zip
Merge remote-tracking branch 'pochu-public/log-window-619866' into empathy-skype
Conflicts: libempathy-gtk/empathy-log-window.c libempathy/empathy-message.c
Diffstat (limited to 'libempathy/empathy-message.c')
-rw-r--r--libempathy/empathy-message.c43
1 files changed, 30 insertions, 13 deletions
diff --git a/libempathy/empathy-message.c b/libempathy/empathy-message.c
index 076a10053..322fb2df9 100644
--- a/libempathy/empathy-message.c
+++ b/libempathy/empathy-message.c
@@ -26,6 +26,8 @@
#include <string.h>
+#include <glib/gi18n-lib.h>
+
#include <telepathy-glib/util.h>
#include <telepathy-glib/account.h>
#include <telepathy-glib/account-manager.h>
@@ -33,6 +35,7 @@
#include <telepathy-logger/entity.h>
#include <telepathy-logger/event.h>
#include <telepathy-logger/text-event.h>
+#include <telepathy-logger/call-event.h>
#include "empathy-message.h"
#include "empathy-utils.h"
@@ -302,19 +305,33 @@ empathy_message_from_tpl_log_event (TplEvent *logevent)
tpl_event_get_account_path (logevent));
g_object_unref (acc_man);
- /* TODO Currently only TplTextEvent exists as subclass of TplEvent, in
- * future more TplEvent will exist and EmpathyMessage should probably
- * be enhanced to support other types of log entries (ie TplCallEvent).
- *
- * For now we just check (simply) that we are dealing with the only supported type,
- * then there will be a if/then/else or switch handling all the supported
- * cases.
- */
- if (!TPL_IS_TEXT_EVENT (logevent))
- return NULL;
-
- body = g_strdup (tpl_text_event_get_message (
- TPL_TEXT_EVENT (logevent)));
+ if (TPL_IS_TEXT_EVENT (logevent)) {
+ body = g_strdup (tpl_text_event_get_message (
+ TPL_TEXT_EVENT (logevent)));
+
+ retval = empathy_message_new (body);
+
+ empathy_message_set_tptype (retval,
+ tpl_text_event_get_message_type (TPL_TEXT_EVENT (logevent)));
+ empathy_message_set_is_backlog (retval, TRUE);
+
+ g_free (body);
+ } else if (TPL_IS_CALL_EVENT (logevent)) {
+ TplCallEvent *call = TPL_CALL_EVENT (logevent);
+ if (tpl_call_event_get_end_reason (call) == TPL_CALL_END_REASON_NO_ANSWER)
+ body = g_strdup_printf (_("Missed call from %s"),
+ tpl_entity_get_alias (tpl_event_get_sender (logevent)));
+ else if (tpl_entity_get_entity_type (tpl_event_get_sender (logevent)) == TPL_ENTITY_SELF)
+ body = g_strdup_printf (_("Called %s"),
+ tpl_entity_get_alias (tpl_event_get_receiver (logevent)));
+ else
+ body = g_strdup_printf (_("Call from %s"),
+ tpl_entity_get_alias (tpl_event_get_sender (logevent)));
+
+ retval = empathy_message_new (body);
+ g_free (body);
+ }
+
receiver = tpl_event_get_receiver (logevent);
sender = tpl_event_get_sender (logevent);