summaryrefslogtreecommitdiff
path: root/daemon/gvfsjobseekread.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/gvfsjobseekread.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/gvfsjobseekread.c')
-rw-r--r--daemon/gvfsjobseekread.c37
1 files changed, 28 insertions, 9 deletions
diff --git a/daemon/gvfsjobseekread.c b/daemon/gvfsjobseekread.c
index 0e898cf1..2314e264 100644
--- a/daemon/gvfsjobseekread.c
+++ b/daemon/gvfsjobseekread.c
@@ -13,8 +13,9 @@
G_DEFINE_TYPE (GVfsJobSeekRead, g_vfs_job_seek_read, G_TYPE_VFS_JOB);
-static gboolean start (GVfsJob *job);
-static void send_reply (GVfsJob *job);
+static void run (GVfsJob *job);
+static gboolean try (GVfsJob *job);
+static void send_reply (GVfsJob *job);
static void
g_vfs_job_seek_read_finalize (GObject *object)
@@ -36,7 +37,8 @@ g_vfs_job_seek_read_class_init (GVfsJobSeekReadClass *klass)
gobject_class->finalize = g_vfs_job_seek_read_finalize;
- job_class->start = start;
+ job_class->run = run;
+ job_class->try = try;
job_class->send_reply = send_reply;
}
@@ -83,16 +85,33 @@ send_reply (GVfsJob *job)
}
}
+static void
+run (GVfsJob *job)
+{
+ GVfsJobSeekRead *op_job = G_VFS_JOB_SEEK_READ (job);
+ GVfsBackendClass *class = G_VFS_BACKEND_GET_CLASS (op_job->backend);
+
+ class->seek_on_read (op_job->backend,
+ op_job,
+ op_job->handle,
+ op_job->requested_offset,
+ op_job->seek_type);
+}
+
static gboolean
-start (GVfsJob *job)
+try (GVfsJob *job)
{
GVfsJobSeekRead *op_job = G_VFS_JOB_SEEK_READ (job);
+ GVfsBackendClass *class = G_VFS_BACKEND_GET_CLASS (op_job->backend);
- return g_vfs_backend_seek_on_read (op_job->backend,
- op_job,
- op_job->handle,
- op_job->requested_offset,
- op_job->seek_type);
+ if (class->try_seek_on_read == NULL)
+ return FALSE;
+
+ return class->try_seek_on_read (op_job->backend,
+ op_job,
+ op_job->handle,
+ op_job->requested_offset,
+ op_job->seek_type);
}
void