[libgdata] core: Add some comments about the lifecycle of GDataDownloadStream
- From: Philip Withnall <pwithnall src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [libgdata] core: Add some comments about the lifecycle of GDataDownloadStream
- Date: Mon, 20 Dec 2010 13:47:58 +0000 (UTC)
commit 1d32533173641103283c2fc201821cd50e7f180d
Author: Philip Withnall <philip tecnocode co uk>
Date: Thu Dec 16 19:16:58 2010 +0000
core: Add some comments about the lifecycle of GDataDownloadStream
Helps: bgo#637036
gdata/gdata-download-stream.c | 10 ++++++++++
1 files changed, 10 insertions(+), 0 deletions(-)
---
diff --git a/gdata/gdata-download-stream.c b/gdata/gdata-download-stream.c
index a12a4a2..72de537 100644
--- a/gdata/gdata-download-stream.c
+++ b/gdata/gdata-download-stream.c
@@ -62,6 +62,16 @@ static gboolean gdata_download_stream_truncate (GSeekable *seekable, goffset off
static void create_network_thread (GDataDownloadStream *self, GError **error);
+/*
+ * The GDataDownloadStream can be in one of several states:
+ * 1. Pre-network activity. This is the state that the stream is created in. @network_thread and @cancellable are both %NULL, and @finished is %FALSE.
+ * The stream will remain in this state until gdata_download_stream_read() or gdata_download_stream_seek() are called for the first time.
+ * 2. Network activity. This state is entered when gdata_download_stream_read() or gdata_download_stream_seek() are called for the first time.
+ * @network_thread and @cancellable are created, while @finished remains %FALSE.
+ * 3. Post-network activity. This state is reached once the download thread finishes downloading, either due to having downloaded everything, or due
+ * to being cancelled by gdata_download_stream_close(). @network_thread is non-%NULL, but meaningless; @cancellable is still a valid #GCancellable
+ * instance; and @finished is set to %TRUE. At the same time, @finished_cond is signalled. The stream remains in this state until it's destroyed.
+ */
struct _GDataDownloadStreamPrivate {
gchar *download_uri;
GDataService *service;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]