summaryrefslogtreecommitdiff
path: root/daemon/gvfsjobcloseread.c
diff options
context:
space:
mode:
authorAlexander Larsson <alexl@src.gnome.org>2007-09-13 11:03:09 +0000
committerAlexander Larsson <alexl@src.gnome.org>2007-09-13 11:03:09 +0000
commitf043c47e0efb3c443f040d5238d657ea6a0ed26b (patch)
tree8618fbd14ab34bea70dc4a2606be0fdaa604101a /daemon/gvfsjobcloseread.c
parent44fce9a8d15caf9c660ccc30eb8046727a54152c (diff)
downloadgvfs-f043c47e0efb3c443f040d5238d657ea6a0ed26b.tar.gz
New thread model for GVfsDaemon
Original git commit by Alexander Larsson <alex@greebo.(none)> at 1169224526 +0100 svn path=/trunk/; revision=259
Diffstat (limited to 'daemon/gvfsjobcloseread.c')
-rw-r--r--daemon/gvfsjobcloseread.c31
1 files changed, 24 insertions, 7 deletions
diff --git a/daemon/gvfsjobcloseread.c b/daemon/gvfsjobcloseread.c
index 4ea7904a..e39846ae 100644
--- a/daemon/gvfsjobcloseread.c
+++ b/daemon/gvfsjobcloseread.c
@@ -13,7 +13,8 @@
G_DEFINE_TYPE (GVfsJobCloseRead, g_vfs_job_close_read, G_TYPE_VFS_JOB);
-static gboolean start (GVfsJob *job);
+static void run (GVfsJob *job);
+static gboolean try (GVfsJob *job);
static void send_reply (GVfsJob *job);
static void
@@ -36,7 +37,8 @@ g_vfs_job_close_read_class_init (GVfsJobCloseReadClass *klass)
gobject_class->finalize = g_vfs_job_close_read_finalize;
- job_class->start = start;
+ job_class->run = run;
+ job_class->try = try;
job_class->send_reply = send_reply;
}
@@ -76,12 +78,27 @@ send_reply (GVfsJob *job)
g_vfs_read_channel_send_closed (op_job->channel);
}
-static gboolean
-start (GVfsJob *job)
+static void
+run (GVfsJob *job)
{
GVfsJobCloseRead *op_job = G_VFS_JOB_CLOSE_READ (job);
+ GVfsBackendClass *class = G_VFS_BACKEND_GET_CLASS (op_job->backend);
+
+ class->close_read (op_job->backend,
+ op_job,
+ op_job->handle);
+}
- return g_vfs_backend_close_read (op_job->backend,
- op_job,
- op_job->handle);
+static gboolean
+try (GVfsJob *job)
+{
+ GVfsJobCloseRead *op_job = G_VFS_JOB_CLOSE_READ (job);
+ GVfsBackendClass *class = G_VFS_BACKEND_GET_CLASS (op_job->backend);
+
+ if (class->try_close_read == NULL)
+ return FALSE;
+
+ return class->try_close_read (op_job->backend,
+ op_job,
+ op_job->handle);
}