diff options
-rw-r--r-- | libempathy/empathy-tp-file.c | 399 | ||||
-rw-r--r-- | libempathy/empathy-tp-file.h | 3 |
2 files changed, 182 insertions, 220 deletions
diff --git a/libempathy/empathy-tp-file.c b/libempathy/empathy-tp-file.c index a9ef227c6..cdb3bfab9 100644 --- a/libempathy/empathy-tp-file.c +++ b/libempathy/empathy-tp-file.c @@ -65,7 +65,7 @@ /* EmpathyTpFile object */ -typedef struct { +struct _EmpathyTpFilePrivate { TpChannel *channel; GInputStream *in_stream; @@ -97,7 +97,7 @@ typedef struct { gboolean is_closed; gboolean dispose_run; -} EmpathyTpFilePriv; +}; enum { PROP_0, @@ -105,8 +105,6 @@ enum { PROP_INCOMING }; -#define GET_PRIV(obj) EMPATHY_GET_PRIV (obj, EmpathyTpFile) - G_DEFINE_TYPE (EmpathyTpFile, empathy_tp_file, G_TYPE_OBJECT); /* private functions */ @@ -118,16 +116,16 @@ tp_file_get_state_cb (TpProxy *proxy, gpointer user_data, GObject *weak_object) { - EmpathyTpFilePriv *priv = GET_PRIV (weak_object); + EmpathyTpFile *self = (EmpathyTpFile *) weak_object; if (error != NULL) { /* set a default value for the state */ - priv->state = TP_FILE_TRANSFER_STATE_NONE; + self->priv->state = TP_FILE_TRANSFER_STATE_NONE; return; } - priv->state = g_value_get_uint (value); + self->priv->state = g_value_get_uint (value); } static void @@ -137,7 +135,7 @@ tp_file_get_available_socket_types_cb (TpProxy *proxy, gpointer user_data, GObject *weak_object) { - EmpathyTpFilePriv *priv = GET_PRIV (weak_object); + EmpathyTpFile *self = (EmpathyTpFile *) weak_object; GHashTable *socket_types; GArray *access_controls; @@ -145,8 +143,8 @@ tp_file_get_available_socket_types_cb (TpProxy *proxy, !G_VALUE_HOLDS (value, TP_HASH_TYPE_SUPPORTED_SOCKET_MAP)) { /* set a default value */ - priv->socket_address_type = TP_SOCKET_ADDRESS_TYPE_UNIX; - priv->socket_access_control = TP_SOCKET_ACCESS_CONTROL_LOCALHOST; + self->priv->socket_address_type = TP_SOCKET_ADDRESS_TYPE_UNIX; + self->priv->socket_access_control = TP_SOCKET_ACCESS_CONTROL_LOCALHOST; goto out; } @@ -156,26 +154,26 @@ tp_file_get_available_socket_types_cb (TpProxy *proxy, if ((access_controls = g_hash_table_lookup (socket_types, GUINT_TO_POINTER (TP_SOCKET_ADDRESS_TYPE_UNIX))) != NULL) { - priv->socket_address_type = TP_SOCKET_ADDRESS_TYPE_UNIX; - priv->socket_access_control = TP_SOCKET_ACCESS_CONTROL_LOCALHOST; + self->priv->socket_address_type = TP_SOCKET_ADDRESS_TYPE_UNIX; + self->priv->socket_access_control = TP_SOCKET_ACCESS_CONTROL_LOCALHOST; goto out; } if ((access_controls = g_hash_table_lookup (socket_types, GUINT_TO_POINTER (TP_SOCKET_ADDRESS_TYPE_IPV4))) != NULL) { - priv->socket_address_type = TP_SOCKET_ADDRESS_TYPE_IPV4; + self->priv->socket_address_type = TP_SOCKET_ADDRESS_TYPE_IPV4; /* TODO: we should prefer PORT over LOCALHOST when the CM will * support it. */ - priv->socket_access_control = TP_SOCKET_ACCESS_CONTROL_LOCALHOST; + self->priv->socket_access_control = TP_SOCKET_ACCESS_CONTROL_LOCALHOST; } out: DEBUG ("Socket address type: %u, access control %u", - priv->socket_address_type, priv->socket_access_control); + self->priv->socket_address_type, self->priv->socket_access_control); } static void @@ -183,57 +181,51 @@ tp_file_invalidated_cb (TpProxy *proxy, guint domain, gint code, gchar *message, - EmpathyTpFile *tp_file) + EmpathyTpFile *self) { - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - DEBUG ("Channel invalidated: %s", message); - if (priv->state != TP_FILE_TRANSFER_STATE_COMPLETED && - priv->state != TP_FILE_TRANSFER_STATE_CANCELLED) + if (self->priv->state != TP_FILE_TRANSFER_STATE_COMPLETED && + self->priv->state != TP_FILE_TRANSFER_STATE_CANCELLED) { /* The channel is not in a finished state, an error occured */ - priv->state = TP_FILE_TRANSFER_STATE_CANCELLED; - priv->state_change_reason = + self->priv->state = TP_FILE_TRANSFER_STATE_CANCELLED; + self->priv->state_change_reason = TP_FILE_TRANSFER_STATE_CHANGE_REASON_LOCAL_ERROR; } } static void -ft_operation_close_clean (EmpathyTpFile *tp_file) +ft_operation_close_clean (EmpathyTpFile *self) { - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - - if (priv->is_closed) + if (self->priv->is_closed) return; DEBUG ("FT operation close clean"); - priv->is_closed = TRUE; + self->priv->is_closed = TRUE; - if (priv->op_callback != NULL) - priv->op_callback (tp_file, NULL, priv->op_user_data); + if (self->priv->op_callback != NULL) + self->priv->op_callback (self, NULL, self->priv->op_user_data); } static void -ft_operation_close_with_error (EmpathyTpFile *tp_file, +ft_operation_close_with_error (EmpathyTpFile *self, GError *error) { - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - - if (priv->is_closed) + if (self->priv->is_closed) return; DEBUG ("FT operation close with error %s", error->message); - priv->is_closed = TRUE; + self->priv->is_closed = TRUE; /* close the channel if it's not cancelled already */ - if (priv->state != TP_FILE_TRANSFER_STATE_CANCELLED) - empathy_tp_file_cancel (tp_file); + if (self->priv->state != TP_FILE_TRANSFER_STATE_CANCELLED) + empathy_tp_file_cancel (self); - if (priv->op_callback != NULL) - priv->op_callback (tp_file, error, priv->op_user_data); + if (self->priv->op_callback != NULL) + self->priv->op_callback (self, error, self->priv->op_user_data); } static void @@ -241,39 +233,34 @@ splice_stream_ready_cb (GObject *source, GAsyncResult *res, gpointer user_data) { - EmpathyTpFile *tp_file; - EmpathyTpFilePriv *priv; + EmpathyTpFile *self = user_data; GError *error = NULL; - tp_file = user_data; - priv = GET_PRIV (tp_file); - g_output_stream_splice_finish (G_OUTPUT_STREAM (source), res, &error); DEBUG ("Splice stream ready cb, error %p", error); - if (error != NULL && !priv->is_closing) + if (error != NULL && !self->priv->is_closing) { - ft_operation_close_with_error (tp_file, error); + ft_operation_close_with_error (self, error); g_clear_error (&error); return; } } static void -tp_file_start_transfer (EmpathyTpFile *tp_file) +tp_file_start_transfer (EmpathyTpFile *self) { gint fd, domain, res = 0; GError *error = NULL; struct sockaddr *my_addr = NULL; size_t my_size = 0; - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - if (priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_UNIX) + if (self->priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_UNIX) { domain = AF_UNIX; } - else if (priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_IPV4) + else if (self->priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_IPV4) { domain = AF_INET; } @@ -284,7 +271,7 @@ tp_file_start_transfer (EmpathyTpFile *tp_file) DEBUG ("Socket not supported, closing channel"); - ft_operation_close_with_error (tp_file, error); + ft_operation_close_with_error (self, error); g_clear_error (&error); return; @@ -301,32 +288,32 @@ tp_file_start_transfer (EmpathyTpFile *tp_file) DEBUG ("Failed to create socket, closing channel"); - ft_operation_close_with_error (tp_file, error); + ft_operation_close_with_error (self, error); g_clear_error (&error); return; } - if (priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_UNIX) + if (self->priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_UNIX) { struct sockaddr_un addr; memset (&addr, 0, sizeof (addr)); addr.sun_family = domain; - strncpy (addr.sun_path, priv->socket_address->data, - priv->socket_address->len); + strncpy (addr.sun_path, self->priv->socket_address->data, + self->priv->socket_address->len); my_addr = (struct sockaddr *) &addr; my_size = sizeof (addr); } - else if (priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_IPV4) + else if (self->priv->socket_address_type == TP_SOCKET_ADDRESS_TYPE_IPV4) { struct sockaddr_in addr; memset (&addr, 0, sizeof (addr)); addr.sin_family = domain; - inet_pton (AF_INET, priv->socket_address->data, &addr.sin_addr); - addr.sin_port = htons (priv->port); + inet_pton (AF_INET, self->priv->socket_address->data, &addr.sin_addr); + addr.sin_port = htons (self->priv->port); my_addr = (struct sockaddr *) &addr; my_size = sizeof (addr); @@ -343,7 +330,7 @@ tp_file_start_transfer (EmpathyTpFile *tp_file) DEBUG ("Failed to connect socket, closing channel"); - ft_operation_close_with_error (tp_file, error); + ft_operation_close_with_error (self, error); close (fd); g_clear_error (&error); @@ -352,23 +339,23 @@ tp_file_start_transfer (EmpathyTpFile *tp_file) DEBUG ("Start the transfer"); - priv->start_time = empathy_time_get_current (); + self->priv->start_time = empathy_time_get_current (); /* notify we're starting a transfer */ - if (priv->progress_callback != NULL) - priv->progress_callback (tp_file, 0, priv->progress_user_data); + if (self->priv->progress_callback != NULL) + self->priv->progress_callback (self, 0, self->priv->progress_user_data); - if (priv->incoming) + if (self->priv->incoming) { GInputStream *socket_stream; socket_stream = g_unix_input_stream_new (fd, TRUE); - g_output_stream_splice_async (priv->out_stream, socket_stream, + g_output_stream_splice_async (self->priv->out_stream, socket_stream, G_OUTPUT_STREAM_SPLICE_CLOSE_SOURCE | G_OUTPUT_STREAM_SPLICE_CLOSE_TARGET, - G_PRIORITY_DEFAULT, priv->cancellable, - splice_stream_ready_cb, tp_file); + G_PRIORITY_DEFAULT, self->priv->cancellable, + splice_stream_ready_cb, self); g_object_unref (socket_stream); } @@ -378,11 +365,11 @@ tp_file_start_transfer (EmpathyTpFile *tp_file) socket_stream = g_unix_output_stream_new (fd, TRUE); - g_output_stream_splice_async (socket_stream, priv->in_stream, + g_output_stream_splice_async (socket_stream, self->priv->in_stream, G_OUTPUT_STREAM_SPLICE_CLOSE_SOURCE | G_OUTPUT_STREAM_SPLICE_CLOSE_TARGET, - G_PRIORITY_DEFAULT, priv->cancellable, - splice_stream_ready_cb, tp_file); + G_PRIORITY_DEFAULT, self->priv->cancellable, + splice_stream_ready_cb, self); g_object_unref (socket_stream); } @@ -434,29 +421,29 @@ tp_file_state_changed_cb (TpChannel *proxy, gpointer user_data, GObject *weak_object) { - EmpathyTpFilePriv *priv = GET_PRIV (weak_object); + EmpathyTpFile *self = (EmpathyTpFile *) weak_object; GError *error = NULL; - if (state == priv->state) + if (state == self->priv->state) return; DEBUG ("File transfer state changed:\n" "old state = %u, state = %u, reason = %u\n" "\tincoming = %s, in_stream = %s, out_stream = %s", - priv->state, state, reason, - priv->incoming ? "yes" : "no", - priv->in_stream ? "present" : "not present", - priv->out_stream ? "present" : "not present"); + self->priv->state, state, reason, + self->priv->incoming ? "yes" : "no", + self->priv->in_stream ? "present" : "not present", + self->priv->out_stream ? "present" : "not present"); - priv->state = state; - priv->state_change_reason = reason; + self->priv->state = state; + self->priv->state_change_reason = reason; /* 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 == TP_FILE_TRANSFER_STATE_OPEN && - priv->socket_address != NULL) + self->priv->socket_address != NULL) tp_file_start_transfer (EMPATHY_TP_FILE (weak_object)); if (state == TP_FILE_TRANSFER_STATE_COMPLETED) @@ -464,7 +451,7 @@ tp_file_state_changed_cb (TpChannel *proxy, if (state == TP_FILE_TRANSFER_STATE_CANCELLED) { - error = error_from_state_change_reason (priv->state_change_reason); + error = error_from_state_change_reason (self->priv->state_change_reason); ft_operation_close_with_error (EMPATHY_TP_FILE (weak_object), error); g_clear_error (&error); } @@ -476,16 +463,16 @@ tp_file_transferred_bytes_changed_cb (TpChannel *proxy, gpointer user_data, GObject *weak_object) { - EmpathyTpFilePriv *priv = GET_PRIV (weak_object); + EmpathyTpFile *self = (EmpathyTpFile *) weak_object; /* don't notify for 0 bytes count */ if (count == 0) return; /* notify clients */ - if (priv->progress_callback != NULL) - priv->progress_callback (EMPATHY_TP_FILE (weak_object), - count, priv->progress_user_data); + if (self->priv->progress_callback != NULL) + self->priv->progress_callback (EMPATHY_TP_FILE (weak_object), + count, self->priv->progress_user_data); } static void @@ -495,11 +482,10 @@ ft_operation_provide_or_accept_file_cb (TpChannel *proxy, gpointer user_data, GObject *weak_object) { - EmpathyTpFile *tp_file = EMPATHY_TP_FILE (weak_object); + EmpathyTpFile *self = EMPATHY_TP_FILE (weak_object); GError *myerr = NULL; - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - g_cancellable_set_error_if_cancelled (priv->cancellable, &myerr); + g_cancellable_set_error_if_cancelled (self->priv->cancellable, &myerr); if (error != NULL) { @@ -517,14 +503,14 @@ ft_operation_provide_or_accept_file_cb (TpChannel *proxy, if (myerr != NULL) { DEBUG ("Error: %s", myerr->message); - ft_operation_close_with_error (tp_file, myerr); + ft_operation_close_with_error (self, myerr); g_clear_error (&myerr); return; } if (G_VALUE_TYPE (address) == DBUS_TYPE_G_UCHAR_ARRAY) { - priv->socket_address = g_value_dup_boxed (address); + self->priv->socket_address = g_value_dup_boxed (address); } else if (G_VALUE_TYPE (address) == G_TYPE_STRING) { @@ -533,9 +519,9 @@ ft_operation_provide_or_accept_file_cb (TpChannel *proxy, const gchar *path; path = g_value_get_string (address); - priv->socket_address = g_array_sized_new (TRUE, FALSE, sizeof (gchar), - strlen (path)); - g_array_insert_vals (priv->socket_address, 0, path, strlen (path)); + self->priv->socket_address = g_array_sized_new (TRUE, FALSE, + sizeof (gchar), strlen (path)); + g_array_insert_vals (self->priv->socket_address, 0, path, strlen (path)); } else if (G_VALUE_TYPE (address) == TP_STRUCT_TYPE_SOCKET_ADDRESS_IPV4) { @@ -548,23 +534,23 @@ ft_operation_provide_or_accept_file_cb (TpChannel *proxy, /* IPV4 address */ v = g_value_array_get_nth (val_array, 0); addr = g_value_get_string (v); - priv->socket_address = g_array_sized_new (TRUE, FALSE, sizeof (gchar), - strlen (addr)); - g_array_insert_vals (priv->socket_address, 0, addr, strlen (addr)); + self->priv->socket_address = g_array_sized_new (TRUE, FALSE, + sizeof (gchar), strlen (addr)); + g_array_insert_vals (self->priv->socket_address, 0, addr, strlen (addr)); /* port number */ v = g_value_array_get_nth (val_array, 1); - priv->port = g_value_get_uint (v); + self->priv->port = g_value_get_uint (v); } DEBUG ("Got socket address: %s, port (not zero if IPV4): %d", - priv->socket_address->data, priv->port); + self->priv->socket_address->data, self->priv->port); /* if the channel is already open, start the transfer now, otherwise, * wait for the state change signal. */ - if (priv->state == TP_FILE_TRANSFER_STATE_OPEN) - tp_file_start_transfer (tp_file); + if (self->priv->state == TP_FILE_TRANSFER_STATE_OPEN) + tp_file_start_transfer (self); } static void @@ -585,34 +571,31 @@ file_read_async_cb (GObject *source, gpointer user_data) { GValue nothing = { 0 }; - EmpathyTpFile *tp_file = user_data; - EmpathyTpFilePriv *priv; + EmpathyTpFile *self = user_data; GFileInputStream *in_stream; GError *error = NULL; - priv = GET_PRIV (tp_file); - in_stream = g_file_read_finish (G_FILE (source), res, &error); - if (error != NULL && !priv->is_closing) + if (error != NULL && !self->priv->is_closing) { - ft_operation_close_with_error (tp_file, error); + ft_operation_close_with_error (self, error); g_clear_error (&error); return; } - priv->in_stream = G_INPUT_STREAM (in_stream); + self->priv->in_stream = G_INPUT_STREAM (in_stream); /* we don't impose specific interface/port requirements even * if we're not using UNIX sockets. */ - initialize_empty_ac_variant (priv->socket_access_control, ¬hing); + initialize_empty_ac_variant (self->priv->socket_access_control, ¬hing); tp_cli_channel_type_file_transfer_call_provide_file ( - priv->channel, -1, - priv->socket_address_type, priv->socket_access_control, + self->priv->channel, -1, + self->priv->socket_address_type, self->priv->socket_access_control, ¬hing, ft_operation_provide_or_accept_file_cb, - NULL, NULL, G_OBJECT (tp_file)); + NULL, NULL, G_OBJECT (self)); } static void @@ -623,7 +606,6 @@ file_transfer_set_uri_cb (TpProxy *proxy, { GValue nothing = { 0 }; EmpathyTpFile *self = (EmpathyTpFile *) weak_object; - EmpathyTpFilePriv *priv = GET_PRIV (self); if (error != NULL) { @@ -634,11 +616,11 @@ file_transfer_set_uri_cb (TpProxy *proxy, /* we don't impose specific interface/port requirements even * if we're not using UNIX sockets. */ - initialize_empty_ac_variant (priv->socket_access_control, ¬hing); + initialize_empty_ac_variant (self->priv->socket_access_control, ¬hing); - tp_cli_channel_type_file_transfer_call_accept_file (priv->channel, - -1, priv->socket_address_type, priv->socket_access_control, - ¬hing, priv->offset, + tp_cli_channel_type_file_transfer_call_accept_file (self->priv->channel, + -1, self->priv->socket_address_type, self->priv->socket_access_control, + ¬hing, self->priv->offset, ft_operation_provide_or_accept_file_cb, NULL, NULL, weak_object); } @@ -647,35 +629,32 @@ file_replace_async_cb (GObject *source, GAsyncResult *res, gpointer user_data) { - EmpathyTpFile *tp_file = user_data; - EmpathyTpFilePriv *priv; + EmpathyTpFile *self = user_data; GError *error = NULL; GFileOutputStream *out_stream; GFile *file = G_FILE (source); gchar *uri; GValue *value; - priv = GET_PRIV (tp_file); - out_stream = g_file_replace_finish (file, res, &error); if (error != NULL) { - ft_operation_close_with_error (tp_file, error); + ft_operation_close_with_error (self, error); g_clear_error (&error); return; } - priv->out_stream = G_OUTPUT_STREAM (out_stream); + self->priv->out_stream = G_OUTPUT_STREAM (out_stream); /* Try setting FileTranfer.URI before accepting the file */ uri = g_file_get_uri (file); value = tp_g_value_slice_new_take_string (uri); - tp_cli_dbus_properties_call_set (priv->channel, -1, + tp_cli_dbus_properties_call_set (self->priv->channel, -1, TP_IFACE_CHANNEL_TYPE_FILE_TRANSFER, "URI", value, - file_transfer_set_uri_cb, NULL, NULL, G_OBJECT (tp_file)); + file_transfer_set_uri_cb, NULL, NULL, G_OBJECT (self)); tp_g_value_slice_free (value); } @@ -686,71 +665,64 @@ channel_closed_cb (TpChannel *proxy, gpointer user_data, GObject *weak_object) { - EmpathyTpFile *tp_file = EMPATHY_TP_FILE (weak_object); - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); + EmpathyTpFile *self = EMPATHY_TP_FILE (weak_object); gboolean cancel = GPOINTER_TO_INT (user_data); DEBUG ("Channel is closed, should cancel %s", cancel ? "True" : "False"); - if (priv->cancellable != NULL && - !g_cancellable_is_cancelled (priv->cancellable) && cancel) - g_cancellable_cancel (priv->cancellable); + if (self->priv->cancellable != NULL && + !g_cancellable_is_cancelled (self->priv->cancellable) && cancel) + g_cancellable_cancel (self->priv->cancellable); } static void -close_channel_internal (EmpathyTpFile *tp_file, +close_channel_internal (EmpathyTpFile *self, gboolean cancel) { - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - DEBUG ("Closing channel, should cancel %s", cancel ? "True" : "False"); - priv->is_closing = TRUE; + self->priv->is_closing = TRUE; - tp_cli_channel_call_close (priv->channel, -1, - channel_closed_cb, GINT_TO_POINTER (cancel), NULL, G_OBJECT (tp_file)); + tp_cli_channel_call_close (self->priv->channel, -1, + channel_closed_cb, GINT_TO_POINTER (cancel), NULL, G_OBJECT (self)); } /* GObject methods */ static void -empathy_tp_file_init (EmpathyTpFile *tp_file) +empathy_tp_file_init (EmpathyTpFile *self) { - EmpathyTpFilePriv *priv; - - priv = G_TYPE_INSTANCE_GET_PRIVATE ((tp_file), - EMPATHY_TYPE_TP_FILE, EmpathyTpFilePriv); - - tp_file->priv = priv; + self->priv = G_TYPE_INSTANCE_GET_PRIVATE ((self), + EMPATHY_TYPE_TP_FILE, EmpathyTpFilePrivate); } static void do_dispose (GObject *object) { - EmpathyTpFilePriv *priv = GET_PRIV (object); + EmpathyTpFile *self = (EmpathyTpFile *) object; - if (priv->dispose_run) + if (self->priv->dispose_run) return; - priv->dispose_run = TRUE; + self->priv->dispose_run = TRUE; - if (priv->channel != NULL) + if (self->priv->channel != NULL) { - g_signal_handlers_disconnect_by_func (priv->channel, + g_signal_handlers_disconnect_by_func (self->priv->channel, tp_file_invalidated_cb, object); - g_object_unref (priv->channel); - priv->channel = NULL; + g_object_unref (self->priv->channel); + self->priv->channel = NULL; } - if (priv->in_stream != NULL) - g_object_unref (priv->in_stream); + if (self->priv->in_stream != NULL) + g_object_unref (self->priv->in_stream); - if (priv->out_stream != NULL) - g_object_unref (priv->out_stream); + if (self->priv->out_stream != NULL) + g_object_unref (self->priv->out_stream); - if (priv->cancellable != NULL) - g_object_unref (priv->cancellable); + if (self->priv->cancellable != NULL) + g_object_unref (self->priv->cancellable); G_OBJECT_CLASS (empathy_tp_file_parent_class)->dispose (object); } @@ -758,14 +730,14 @@ do_dispose (GObject *object) static void do_finalize (GObject *object) { - EmpathyTpFilePriv *priv = GET_PRIV (object); + EmpathyTpFile *self = (EmpathyTpFile *) object; DEBUG ("%p", object); - if (priv->socket_address != NULL) + if (self->priv->socket_address != NULL) { - g_array_free (priv->socket_address, TRUE); - priv->socket_address = NULL; + g_array_free (self->priv->socket_address, TRUE); + self->priv->socket_address = NULL; } G_OBJECT_CLASS (empathy_tp_file_parent_class)->finalize (object); @@ -777,15 +749,15 @@ do_get_property (GObject *object, GValue *value, GParamSpec *pspec) { - EmpathyTpFilePriv *priv = GET_PRIV (object); + EmpathyTpFile *self = (EmpathyTpFile *) object; switch (param_id) { case PROP_CHANNEL: - g_value_set_object (value, priv->channel); + g_value_set_object (value, self->priv->channel); break; case PROP_INCOMING: - g_value_set_boolean (value, priv->incoming); + g_value_set_boolean (value, self->priv->incoming); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec); @@ -799,11 +771,12 @@ do_set_property (GObject *object, const GValue *value, GParamSpec *pspec) { - EmpathyTpFilePriv *priv = GET_PRIV (object); + EmpathyTpFile *self = (EmpathyTpFile *) object; + switch (param_id) { case PROP_CHANNEL: - priv->channel = g_object_ref (g_value_get_object (value)); + self->priv->channel = g_object_ref (g_value_get_object (value)); break; default: G_OBJECT_WARN_INVALID_PROPERTY_ID (object, param_id, pspec); @@ -814,33 +787,29 @@ do_set_property (GObject *object, static void do_constructed (GObject *object) { - EmpathyTpFile *tp_file; - EmpathyTpFilePriv *priv; + EmpathyTpFile *self = (EmpathyTpFile *) object; - tp_file = EMPATHY_TP_FILE (object); - priv = GET_PRIV (tp_file); + g_signal_connect (self->priv->channel, "invalidated", + G_CALLBACK (tp_file_invalidated_cb), self); - g_signal_connect (priv->channel, "invalidated", - G_CALLBACK (tp_file_invalidated_cb), tp_file); - - priv->incoming = !tp_channel_get_requested (priv->channel); + self->priv->incoming = !tp_channel_get_requested (self->priv->channel); tp_cli_channel_type_file_transfer_connect_to_file_transfer_state_changed ( - priv->channel, tp_file_state_changed_cb, NULL, NULL, object, NULL); + self->priv->channel, tp_file_state_changed_cb, NULL, NULL, object, NULL); tp_cli_channel_type_file_transfer_connect_to_transferred_bytes_changed ( - priv->channel, tp_file_transferred_bytes_changed_cb, + self->priv->channel, tp_file_transferred_bytes_changed_cb, NULL, NULL, object, NULL); - tp_cli_dbus_properties_call_get (priv->channel, + tp_cli_dbus_properties_call_get (self->priv->channel, -1, TP_IFACE_CHANNEL_TYPE_FILE_TRANSFER, "State", tp_file_get_state_cb, NULL, NULL, object); - tp_cli_dbus_properties_call_get (priv->channel, + tp_cli_dbus_properties_call_get (self->priv->channel, -1, TP_IFACE_CHANNEL_TYPE_FILE_TRANSFER, "AvailableSocketTypes", tp_file_get_available_socket_types_cb, NULL, NULL, object); - priv->state_change_reason = + self->priv->state_change_reason = TP_FILE_TRANSFER_STATE_CHANGE_REASON_NONE; } @@ -884,7 +853,7 @@ empathy_tp_file_class_init (EmpathyTpFileClass *klass) FALSE, G_PARAM_READABLE)); - g_type_class_add_private (object_class, sizeof (EmpathyTpFilePriv)); + g_type_class_add_private (object_class, sizeof (EmpathyTpFilePrivate)); } /* public methods */ @@ -903,20 +872,20 @@ empathy_tp_file_class_init (EmpathyTpFileClass *klass) EmpathyTpFile * empathy_tp_file_new (TpChannel *channel) { - EmpathyTpFile *tp_file; + EmpathyTpFile *self; g_return_val_if_fail (TP_IS_CHANNEL (channel), NULL); - tp_file = g_object_new (EMPATHY_TYPE_TP_FILE, + self = g_object_new (EMPATHY_TYPE_TP_FILE, "channel", channel, NULL); - return tp_file; + return self; } /** * empathy_tp_file_accept: - * @tp_file: an incoming #EmpathyTpFile + * @self: an incoming #EmpathyTpFile * @offset: the offset of @gfile where we should start writing * @gfile: the destination #GFile for the transfer * @cancellable: a #GCancellable @@ -934,7 +903,7 @@ empathy_tp_file_new (TpChannel *channel) * actually cancel an ongoing #EmpathyTpFile. */ void -empathy_tp_file_accept (EmpathyTpFile *tp_file, +empathy_tp_file_accept (EmpathyTpFile *self, guint64 offset, GFile *gfile, GCancellable *cancellable, @@ -943,27 +912,25 @@ empathy_tp_file_accept (EmpathyTpFile *tp_file, EmpathyTpFileOperationCallback op_callback, gpointer op_user_data) { - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - - g_return_if_fail (EMPATHY_IS_TP_FILE (tp_file)); + g_return_if_fail (EMPATHY_IS_TP_FILE (self)); g_return_if_fail (G_IS_FILE (gfile)); g_return_if_fail (G_IS_CANCELLABLE (cancellable)); - priv->cancellable = g_object_ref (cancellable); - priv->progress_callback = progress_callback; - priv->progress_user_data = progress_user_data; - priv->op_callback = op_callback; - priv->op_user_data = op_user_data; - priv->offset = offset; + self->priv->cancellable = g_object_ref (cancellable); + self->priv->progress_callback = progress_callback; + self->priv->progress_user_data = progress_user_data; + self->priv->op_callback = op_callback; + self->priv->op_user_data = op_user_data; + self->priv->offset = offset; g_file_replace_async (gfile, NULL, FALSE, G_FILE_CREATE_NONE, - G_PRIORITY_DEFAULT, cancellable, file_replace_async_cb, tp_file); + G_PRIORITY_DEFAULT, cancellable, file_replace_async_cb, self); } /** * empathy_tp_file_offer: - * @tp_file: an outgoing #EmpathyTpFile + * @self: an outgoing #EmpathyTpFile * @gfile: the source #GFile for the transfer * @cancellable: a #GCancellable * @progress_callback: function to callback with progress information @@ -980,7 +947,7 @@ empathy_tp_file_accept (EmpathyTpFile *tp_file, * actually cancel an ongoing #EmpathyTpFile. */ void -empathy_tp_file_offer (EmpathyTpFile *tp_file, +empathy_tp_file_offer (EmpathyTpFile *self, GFile *gfile, GCancellable *cancellable, EmpathyTpFileProgressCallback progress_callback, @@ -988,68 +955,62 @@ empathy_tp_file_offer (EmpathyTpFile *tp_file, EmpathyTpFileOperationCallback op_callback, gpointer op_user_data) { - EmpathyTpFilePriv *priv = GET_PRIV (tp_file); - - g_return_if_fail (EMPATHY_IS_TP_FILE (tp_file)); + g_return_if_fail (EMPATHY_IS_TP_FILE (self)); g_return_if_fail (G_IS_FILE (gfile)); g_return_if_fail (G_IS_CANCELLABLE (cancellable)); - priv->cancellable = g_object_ref (cancellable); - priv->progress_callback = progress_callback; - priv->progress_user_data = progress_user_data; - priv->op_callback = op_callback; - priv->op_user_data = op_user_data; + self->priv->cancellable = g_object_ref (cancellable); + self->priv->progress_callback = progress_callback; + self->priv->progress_user_data = progress_user_data; + self->priv->op_callback = op_callback; + self->priv->op_user_data = op_user_data; g_file_read_async (gfile, G_PRIORITY_DEFAULT, cancellable, - file_read_async_cb, tp_file); + file_read_async_cb, self); } /** * empathy_tp_file_is_incoming: - * @tp_file: an #EmpathyTpFile + * @self: an #EmpathyTpFile * - * Returns whether @tp_file is incoming. + * Returns whether @self is incoming. * - * Return value: %TRUE if the @tp_file is incoming, otherwise %FALSE + * Return value: %TRUE if the @self is incoming, otherwise %FALSE */ gboolean -empathy_tp_file_is_incoming (EmpathyTpFile *tp_file) +empathy_tp_file_is_incoming (EmpathyTpFile *self) { - EmpathyTpFilePriv *priv; - - g_return_val_if_fail (EMPATHY_IS_TP_FILE (tp_file), FALSE); - - priv = GET_PRIV (tp_file); + g_return_val_if_fail (EMPATHY_IS_TP_FILE (self), FALSE); - return priv->incoming; + return self->priv->incoming; } /** * empathy_tp_file_cancel: - * @tp_file: an #EmpathyTpFile + * @self: an #EmpathyTpFile * * Cancels an ongoing #EmpathyTpFile, first closing the channel and then * cancelling any I/O operation and closing the socket. */ void -empathy_tp_file_cancel (EmpathyTpFile *tp_file) +empathy_tp_file_cancel (EmpathyTpFile *self) { - g_return_if_fail (EMPATHY_IS_TP_FILE (tp_file)); + g_return_if_fail (EMPATHY_IS_TP_FILE (self)); - close_channel_internal (tp_file, TRUE); + close_channel_internal (self, TRUE); } /** * empathy_tp_file_close: - * @tp_file: an #EmpathyTpFile + * @self: an #EmpathyTpFile * * Closes the channel for an ongoing #EmpathyTpFile. It's safe to call this * method after the transfer has ended. */ void -empathy_tp_file_close (EmpathyTpFile *tp_file) +empathy_tp_file_close (EmpathyTpFile *self) { - g_return_if_fail (EMPATHY_IS_TP_FILE (tp_file)); + g_return_if_fail (EMPATHY_IS_TP_FILE (self)); - close_channel_internal (tp_file, FALSE); + close_channel_internal (self, FALSE); } diff --git a/libempathy/empathy-tp-file.h b/libempathy/empathy-tp-file.h index ad3af72ee..aca8a0f89 100644 --- a/libempathy/empathy-tp-file.h +++ b/libempathy/empathy-tp-file.h @@ -56,11 +56,12 @@ typedef enum { } EmpathyFTErrorEnum; typedef struct _EmpathyTpFile EmpathyTpFile; +typedef struct _EmpathyTpFilePrivate EmpathyTpFilePrivate; typedef struct _EmpathyTpFileClass EmpathyTpFileClass; struct _EmpathyTpFile { GObject parent; - gpointer priv; + EmpathyTpFilePrivate *priv; }; struct _EmpathyTpFileClass { |