summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author <robert.mcqueen@collabora.co.uk>2006-01-19 08:43:23 +0000
committer <robert.mcqueen@collabora.co.uk>2006-01-19 08:43:23 +0000
commitb264d69eb51b85fabe65dada4661e41b87ee9691 (patch)
tree6c4700f65de4b7ff899133594a6984b0c30b3bb6
parent35997d66db7121daabb551d31d4f8577d0eca85a (diff)
fill in send methodSVN_Push_1
-rw-r--r--src/gabble-im-channel.c49
1 files changed, 47 insertions, 2 deletions
diff --git a/src/gabble-im-channel.c b/src/gabble-im-channel.c
index 0a5f29ee7..96904cbc0 100644
--- a/src/gabble-im-channel.c
+++ b/src/gabble-im-channel.c
@@ -19,8 +19,10 @@
*/
#include <dbus/dbus-glib.h>
+#include <loudmouth/loudmouth.h>
#include <stdio.h>
#include <string.h>
+#include <time.h>
#include "allocator.h"
#include "gabble-connection.h"
@@ -71,8 +73,6 @@ struct _GabbleIMChannelPrivate
GabbleHandle handle;
guint recv_id;
- guint send_id;
-
GQueue *pending_messages;
gboolean dispose_has_run;
@@ -644,6 +644,51 @@ gboolean gabble_im_channel_list_pending_messages (GabbleIMChannel *obj, GPtrArra
*/
gboolean gabble_im_channel_send (GabbleIMChannel *obj, guint type, const gchar * text, GError **error)
{
+ GabbleIMChannelPrivate *priv;
+ LmMessage *msg;
+ const char *recipient;
+ gboolean result;
+ time_t timestamp;
+
+ g_assert (GABBLE_IS_IM_CHANNEL (obj));
+
+ priv = GABBLE_IM_CHANNEL_GET_PRIVATE (obj);
+
+ if (type > TP_CHANNEL_TEXT_MESSAGE_TYPE_NOTICE)
+ {
+ g_debug ("gabble_im_channel_send: invalid message type %u", type);
+
+ *error = g_error_new (TELEPATHY_ERRORS, InvalidArgument,
+ "invalid message type: %u", type);
+
+ return FALSE;
+ }
+
+ /* TODO: send different message types */
+
+ recipient = gabble_handle_inspect (
+ _gabble_connection_get_handles (priv->connection),
+ TP_HANDLE_TYPE_CONTACT,
+ priv->handle);
+
+ msg = lm_message_new (recipient, LM_MESSAGE_TYPE_MESSAGE);
+ lm_message_node_add_child (msg->node, "body", text);
+
+ /* TODO: send with callback? */
+
+ result = _gabble_connection_send (priv->connection, msg, error);
+ lm_message_unref (msg);
+
+ if (!result)
+ return FALSE;
+
+ timestamp = time (NULL);
+
+ g_signal_emit (obj, signals[SENT], 0,
+ timestamp,
+ type,
+ text);
+
return TRUE;
}