empathy r1901 - trunk/libempathy
- From: xclaesse svn gnome org
- To: svn-commits-list gnome org
- Subject: empathy r1901 - trunk/libempathy
- Date: Fri, 21 Nov 2008 16:24:25 +0000 (UTC)
Author: xclaesse
Date: Fri Nov 21 16:24:24 2008
New Revision: 1901
URL: http://svn.gnome.org/viewvc/empathy?rev=1901&view=rev
Log:
Fix signature of signal cb, start the transfer only if we have the socket path, and switch input/output streams in tp_file_start_transfer.
Modified:
trunk/libempathy/empathy-tp-file.c
Modified: trunk/libempathy/empathy-tp-file.c
==============================================================================
--- trunk/libempathy/empathy-tp-file.c (original)
+++ trunk/libempathy/empathy-tp-file.c Fri Nov 21 16:24:24 2008
@@ -426,30 +426,36 @@
tp_file->priv->cancellable = g_cancellable_new ();
if (tp_file->priv->incoming)
{
- GOutputStream *socket_stream;
+ GInputStream *socket_stream;
- socket_stream = g_unix_output_stream_new (fd, TRUE);
- copy_stream (tp_file->priv->in_stream, socket_stream,
+ socket_stream = g_unix_input_stream_new (fd, TRUE);
+ copy_stream (socket_stream, tp_file->priv->out_stream,
tp_file->priv->cancellable);
g_object_unref (socket_stream);
}
else
{
- GInputStream *socket_stream;
+ GOutputStream *socket_stream;
- socket_stream = g_unix_input_stream_new (fd, TRUE);
- copy_stream (socket_stream, tp_file->priv->out_stream,
+ socket_stream = g_unix_output_stream_new (fd, TRUE);
+ copy_stream (tp_file->priv->in_stream, socket_stream,
tp_file->priv->cancellable);
g_object_unref (socket_stream);
}
}
static void
-tp_file_state_changed_cb (DBusGProxy *tp_file_iface,
- EmpFileTransferState state,
- EmpFileTransferStateChangeReason reason,
- EmpathyTpFile *tp_file)
+tp_file_state_changed_cb (TpProxy *proxy,
+ guint state,
+ guint reason,
+ gpointer user_data,
+ GObject *weak_object)
{
+ EmpathyTpFile *tp_file = EMPATHY_TP_FILE (weak_object);
+
+ if (state == tp_file->priv->state)
+ return;
+
DEBUG ("File transfer state changed:\n"
"\tfilename = %s, old state = %u, state = %u, reason = %u\n"
"\tincoming = %s, in_stream = %s, out_stream = %s",
@@ -458,7 +464,11 @@
tp_file->priv->in_stream ? "present" : "not present",
tp_file->priv->out_stream ? "present" : "not present");
- if (state == EMP_FILE_TRANSFER_STATE_OPEN)
+ /* If the channel is open AND we have the socket path, we can start the
+ * transfer. The socket path could be NULL if we are not doing the actual
+ * data transfer but are just an observer for the channel. */
+ if (state == EMP_FILE_TRANSFER_STATE_OPEN &&
+ tp_file->priv->unix_socket_path != NULL)
tp_file_start_transfer (tp_file);
tp_file->priv->state = state;
@@ -470,14 +480,15 @@
static void
tp_file_transferred_bytes_changed_cb (TpProxy *proxy,
guint64 count,
- EmpathyTpFile *tp_file,
+ gpointer user_data,
GObject *weak_object)
{
+ EmpathyTpFile *tp_file = EMPATHY_TP_FILE (weak_object);
+
if (tp_file->priv->transferred_bytes == count)
return;
tp_file->priv->transferred_bytes = count;
-
g_object_notify (G_OBJECT (tp_file), "transferred-bytes");
}
@@ -505,18 +516,12 @@
G_CALLBACK (tp_file_invalidated_cb), tp_file);
emp_cli_channel_type_file_transfer_connect_to_file_transfer_state_changed (
- TP_PROXY (tp_file->priv->channel),
- (emp_cli_channel_type_file_transfer_signal_callback_file_transfer_state_changed)
- tp_file_state_changed_cb,
- tp_file,
- NULL, NULL, NULL);
+ TP_PROXY (tp_file->priv->channel), tp_file_state_changed_cb, NULL, NULL,
+ G_OBJECT (tp_file), NULL);
emp_cli_channel_type_file_transfer_connect_to_transferred_bytes_changed (
- TP_PROXY (tp_file->priv->channel),
- (emp_cli_channel_type_file_transfer_signal_callback_transferred_bytes_changed)
- tp_file_transferred_bytes_changed_cb,
- tp_file,
- NULL, NULL, NULL);
+ TP_PROXY (tp_file->priv->channel), tp_file_transferred_bytes_changed_cb,
+ NULL, NULL, G_OBJECT (tp_file), NULL);
account = empathy_channel_get_account (tp_file->priv->channel);
@@ -724,7 +729,6 @@
DEBUG ("Got unix socket path: %s", tp_file->priv->unix_socket_path);
}
-
/**
* empathy_tp_file_accept:
* @tp_file: an #EmpathyTpFile
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]