mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-12 07:26:15 +01:00
Rename gioscheduler calls so they all use the g_io_schedule_ prefix. Split
2007-12-14 Alexander Larsson <alexl@redhat.com> * gioscheduler.[ch]: * gsimpleasyncresult.c: Rename gioscheduler calls so they all use the g_io_schedule_ prefix. Split out the send_to_mainloop call into two versions instead of having the block argument. svn path=/trunk/; revision=6116
This commit is contained in:
parent
2ae689e31f
commit
3db93c01b7
@ -1,3 +1,11 @@
|
|||||||
|
2007-12-14 Alexander Larsson <alexl@redhat.com>
|
||||||
|
|
||||||
|
* gioscheduler.[ch]:
|
||||||
|
* gsimpleasyncresult.c:
|
||||||
|
Rename gioscheduler calls so they all use the g_io_schedule_ prefix.
|
||||||
|
Split out the send_to_mainloop call into two versions instead
|
||||||
|
of having the block argument.
|
||||||
|
|
||||||
2007-12-13 Alexander Larsson <alexl@redhat.com>
|
2007-12-13 Alexander Larsson <alexl@redhat.com>
|
||||||
|
|
||||||
* gcancellable.[ch]:
|
* gcancellable.[ch]:
|
||||||
|
@ -43,10 +43,10 @@
|
|||||||
* </para>
|
* </para>
|
||||||
**/
|
**/
|
||||||
|
|
||||||
struct _GIOJob {
|
struct _GIOSchedulerJob {
|
||||||
GSList *active_link;
|
GSList *active_link;
|
||||||
GIOJobFunc job_func;
|
GIOSchedulerJobFunc job_func;
|
||||||
GIODataFunc cancel_func; /* Runs under job map lock */
|
GSourceFunc cancel_func; /* Runs under job map lock */
|
||||||
gpointer data;
|
gpointer data;
|
||||||
GDestroyNotify destroy_notify;
|
GDestroyNotify destroy_notify;
|
||||||
|
|
||||||
@ -65,7 +65,7 @@ static void io_job_thread (gpointer data,
|
|||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
g_io_job_free (GIOJob *job)
|
g_io_job_free (GIOSchedulerJob *job)
|
||||||
{
|
{
|
||||||
if (job->cancellable)
|
if (job->cancellable)
|
||||||
g_object_unref (job->cancellable);
|
g_object_unref (job->cancellable);
|
||||||
@ -77,8 +77,8 @@ g_io_job_compare (gconstpointer a,
|
|||||||
gconstpointer b,
|
gconstpointer b,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
const GIOJob *aa = a;
|
const GIOSchedulerJob *aa = a;
|
||||||
const GIOJob *bb = b;
|
const GIOSchedulerJob *bb = b;
|
||||||
|
|
||||||
/* Cancelled jobs are set prio == -1, so that
|
/* Cancelled jobs are set prio == -1, so that
|
||||||
they are executed as quickly as possible */
|
they are executed as quickly as possible */
|
||||||
@ -119,9 +119,9 @@ init_scheduler (gpointer arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
remove_active_job (GIOJob *job)
|
remove_active_job (GIOSchedulerJob *job)
|
||||||
{
|
{
|
||||||
GIOJob *other_job;
|
GIOSchedulerJob *other_job;
|
||||||
GSList *l;
|
GSList *l;
|
||||||
gboolean resort_jobs;
|
gboolean resort_jobs;
|
||||||
|
|
||||||
@ -153,7 +153,7 @@ static void
|
|||||||
io_job_thread (gpointer data,
|
io_job_thread (gpointer data,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
GIOJob *job = data;
|
GIOSchedulerJob *job = data;
|
||||||
|
|
||||||
if (job->cancellable)
|
if (job->cancellable)
|
||||||
g_cancellable_push_current (job->cancellable);
|
g_cancellable_push_current (job->cancellable);
|
||||||
@ -172,7 +172,7 @@ io_job_thread (gpointer data,
|
|||||||
static gboolean
|
static gboolean
|
||||||
run_job_at_idle (gpointer data)
|
run_job_at_idle (gpointer data)
|
||||||
{
|
{
|
||||||
GIOJob *job = data;
|
GIOSchedulerJob *job = data;
|
||||||
|
|
||||||
if (job->cancellable)
|
if (job->cancellable)
|
||||||
g_cancellable_push_current (job->cancellable);
|
g_cancellable_push_current (job->cancellable);
|
||||||
@ -192,30 +192,30 @@ run_job_at_idle (gpointer data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_schedule_io_job:
|
* g_io_scheduler_push_job:
|
||||||
* @job_func: a #GIOJobFunc.
|
* @job_func: a #GIOSchedulerJobFunc.
|
||||||
* @user_data: a #gpointer.
|
* @user_data: a #gpointer.
|
||||||
* @notify: a #GDestroyNotify.
|
* @notify: a #GDestroyNotify.
|
||||||
* @io_priority: the <link linkend="gioscheduler">I/O priority</link>
|
* @io_priority: the <link linkend="gioscheduler">I/O priority</link>
|
||||||
* of the request.
|
* of the request.
|
||||||
* @cancellable: optional #GCancellable object, %NULL to ignore.
|
* @cancellable: optional #GCancellable object, %NULL to ignore.
|
||||||
*
|
*
|
||||||
* Schedules the I/O Job.
|
* Schedules the I/O Job to run
|
||||||
*
|
*
|
||||||
**/
|
**/
|
||||||
void
|
void
|
||||||
g_schedule_io_job (GIOJobFunc job_func,
|
g_io_scheduler_push_job (GIOSchedulerJobFunc job_func,
|
||||||
gpointer user_data,
|
gpointer user_data,
|
||||||
GDestroyNotify notify,
|
GDestroyNotify notify,
|
||||||
gint io_priority,
|
gint io_priority,
|
||||||
GCancellable *cancellable)
|
GCancellable *cancellable)
|
||||||
{
|
{
|
||||||
static GOnce once_init = G_ONCE_INIT;
|
static GOnce once_init = G_ONCE_INIT;
|
||||||
GIOJob *job;
|
GIOSchedulerJob *job;
|
||||||
|
|
||||||
g_return_if_fail (job_func != NULL);
|
g_return_if_fail (job_func != NULL);
|
||||||
|
|
||||||
job = g_new0 (GIOJob, 1);
|
job = g_new0 (GIOSchedulerJob, 1);
|
||||||
job->job_func = job_func;
|
job->job_func = job_func;
|
||||||
job->data = user_data;
|
job->data = user_data;
|
||||||
job->destroy_notify = notify;
|
job->destroy_notify = notify;
|
||||||
@ -246,12 +246,12 @@ g_schedule_io_job (GIOJobFunc job_func,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_cancel_all_io_jobs:
|
* g_io_scheduler_cancel_all_jobs:
|
||||||
*
|
*
|
||||||
* Cancels all cancellable I/O Jobs.
|
* Cancels all cancellable I/O Jobs.
|
||||||
**/
|
**/
|
||||||
void
|
void
|
||||||
g_cancel_all_io_jobs (void)
|
g_io_scheduler_cancel_all_jobs (void)
|
||||||
{
|
{
|
||||||
GSList *cancellable_list, *l;
|
GSList *cancellable_list, *l;
|
||||||
|
|
||||||
@ -259,7 +259,7 @@ g_cancel_all_io_jobs (void)
|
|||||||
cancellable_list = NULL;
|
cancellable_list = NULL;
|
||||||
for (l = active_jobs; l != NULL; l = l->next)
|
for (l = active_jobs; l != NULL; l = l->next)
|
||||||
{
|
{
|
||||||
GIOJob *job = l->data;
|
GIOSchedulerJob *job = l->data;
|
||||||
if (job->cancellable)
|
if (job->cancellable)
|
||||||
cancellable_list = g_slist_prepend (cancellable_list,
|
cancellable_list = g_slist_prepend (cancellable_list,
|
||||||
g_object_ref (job->cancellable));
|
g_object_ref (job->cancellable));
|
||||||
@ -276,7 +276,8 @@ g_cancel_all_io_jobs (void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
GIODataFunc func;
|
GSourceFunc func;
|
||||||
|
gboolean ret_val;
|
||||||
gpointer data;
|
gpointer data;
|
||||||
GDestroyNotify notify;
|
GDestroyNotify notify;
|
||||||
|
|
||||||
@ -289,7 +290,7 @@ mainloop_proxy_func (gpointer data)
|
|||||||
{
|
{
|
||||||
MainLoopProxy *proxy = data;
|
MainLoopProxy *proxy = data;
|
||||||
|
|
||||||
proxy->func (proxy->data);
|
proxy->ret_val = proxy->func (proxy->data);
|
||||||
|
|
||||||
if (proxy->notify)
|
if (proxy->notify)
|
||||||
proxy->notify (proxy->data);
|
proxy->notify (proxy->data);
|
||||||
@ -317,21 +318,83 @@ mainloop_proxy_free (MainLoopProxy *proxy)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_io_job_send_to_mainloop:
|
* g_io_scheduler_job_send_to_mainloop:
|
||||||
* @job: a #GIOJob.
|
* @job: a #GIOSchedulerJob.
|
||||||
* @func: a #GIODataFunc callback that will be called the main thread.
|
* @func: a #GSourceFunc callback that will be called in the main thread.
|
||||||
* @user_data: a #gpointer.
|
* @user_data: a #gpointer.
|
||||||
* @notify: a #GDestroyNotify.
|
* @notify: a #GDestroyNotify.
|
||||||
* @block: boolean flag indicating whether or not the job should block until the callback has returned.
|
|
||||||
*
|
*
|
||||||
* Sends a notification from an I/O job to the mainloop processing on the main thread.
|
* Used from an I/O job to send a callback to be run in the main loop (main thread), waiting for
|
||||||
|
* the result (and thus blocking the I/O job).
|
||||||
|
*
|
||||||
|
* Returns: The return value of @func
|
||||||
|
**/
|
||||||
|
gboolean
|
||||||
|
g_io_scheduler_job_send_to_mainloop (GIOSchedulerJob *job,
|
||||||
|
GSourceFunc func,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify)
|
||||||
|
{
|
||||||
|
GSource *source;
|
||||||
|
MainLoopProxy *proxy;
|
||||||
|
guint id;
|
||||||
|
gboolean ret_val;
|
||||||
|
|
||||||
|
g_return_val_if_fail (job != NULL, FALSE);
|
||||||
|
g_return_val_if_fail (func != NULL, FALSE);
|
||||||
|
|
||||||
|
if (job->idle_tag)
|
||||||
|
{
|
||||||
|
/* We just immediately re-enter in the case of idles (non-threads)
|
||||||
|
* Anything else would just deadlock. If you can't handle this, enable threads.
|
||||||
|
*/
|
||||||
|
ret_val = func (user_data);
|
||||||
|
if (notify)
|
||||||
|
notify (user_data);
|
||||||
|
return ret_val;
|
||||||
|
}
|
||||||
|
|
||||||
|
proxy = g_new0 (MainLoopProxy, 1);
|
||||||
|
proxy->func = func;
|
||||||
|
proxy->data = user_data;
|
||||||
|
proxy->notify = notify;
|
||||||
|
proxy->ack_lock = g_mutex_new ();
|
||||||
|
proxy->ack_condition = g_cond_new ();
|
||||||
|
g_mutex_lock (proxy->ack_lock);
|
||||||
|
|
||||||
|
source = g_idle_source_new ();
|
||||||
|
g_source_set_priority (source, G_PRIORITY_DEFAULT);
|
||||||
|
g_source_set_callback (source, mainloop_proxy_func, proxy,
|
||||||
|
NULL);
|
||||||
|
|
||||||
|
id = g_source_attach (source, NULL);
|
||||||
|
g_source_unref (source);
|
||||||
|
|
||||||
|
g_cond_wait (proxy->ack_condition, proxy->ack_lock);
|
||||||
|
g_mutex_unlock (proxy->ack_lock);
|
||||||
|
|
||||||
|
ret_val = proxy->ret_val;
|
||||||
|
mainloop_proxy_free (proxy);
|
||||||
|
|
||||||
|
return ret_val;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* g_io_scheduler_job_send_to_mainloop:
|
||||||
|
* @job: a #GIOSchedulerJob.
|
||||||
|
* @func: a #GSourceFunc callback that will be called in the main thread.
|
||||||
|
* @user_data: a #gpointer.
|
||||||
|
* @notify: a #GDestroyNotify.
|
||||||
|
*
|
||||||
|
* Used from an I/O job to send a callback to be run asynchronously in the main loop (main thread).
|
||||||
|
* The callback will be run when the main loop is availible, but at that time the I/O job
|
||||||
|
* might have finished. The return value from the callback is ignored.
|
||||||
**/
|
**/
|
||||||
void
|
void
|
||||||
g_io_job_send_to_mainloop (GIOJob *job,
|
g_io_scheduler_job_send_to_mainloop_async (GIOSchedulerJob *job,
|
||||||
GIODataFunc func,
|
GSourceFunc func,
|
||||||
gpointer user_data,
|
gpointer user_data,
|
||||||
GDestroyNotify notify,
|
GDestroyNotify notify)
|
||||||
gboolean block)
|
|
||||||
{
|
{
|
||||||
GSource *source;
|
GSource *source;
|
||||||
MainLoopProxy *proxy;
|
MainLoopProxy *proxy;
|
||||||
@ -356,30 +419,15 @@ g_io_job_send_to_mainloop (GIOJob *job,
|
|||||||
proxy->data = user_data;
|
proxy->data = user_data;
|
||||||
proxy->notify = notify;
|
proxy->notify = notify;
|
||||||
|
|
||||||
if (block)
|
|
||||||
{
|
|
||||||
proxy->ack_lock = g_mutex_new ();
|
|
||||||
proxy->ack_condition = g_cond_new ();
|
|
||||||
g_mutex_lock (proxy->ack_lock);
|
|
||||||
}
|
|
||||||
|
|
||||||
source = g_idle_source_new ();
|
source = g_idle_source_new ();
|
||||||
g_source_set_priority (source, G_PRIORITY_DEFAULT);
|
g_source_set_priority (source, G_PRIORITY_DEFAULT);
|
||||||
g_source_set_callback (source, mainloop_proxy_func, proxy,
|
g_source_set_callback (source, mainloop_proxy_func, proxy,
|
||||||
block ? NULL : (GDestroyNotify)mainloop_proxy_free);
|
(GDestroyNotify)mainloop_proxy_free);
|
||||||
|
|
||||||
id = g_source_attach (source, NULL);
|
id = g_source_attach (source, NULL);
|
||||||
g_source_unref (source);
|
g_source_unref (source);
|
||||||
|
|
||||||
if (block)
|
|
||||||
{
|
|
||||||
g_cond_wait (proxy->ack_condition, proxy->ack_lock);
|
|
||||||
g_mutex_unlock (proxy->ack_lock);
|
|
||||||
|
|
||||||
/* In the blocking case we free the proxy here */
|
|
||||||
mainloop_proxy_free (proxy);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#define __G_IO_SCHEDULER_C__
|
#define __G_IO_SCHEDULER_C__
|
||||||
#include "gioaliasdef.c"
|
#include "gioaliasdef.c"
|
||||||
|
@ -29,47 +29,39 @@
|
|||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GIOJob:
|
* GIOSchedulerJob:
|
||||||
*
|
*
|
||||||
* Opaque class for definining and scheduling IO jobs.
|
* Opaque class for definining and scheduling IO jobs.
|
||||||
**/
|
**/
|
||||||
typedef struct _GIOJob GIOJob;
|
typedef struct _GIOSchedulerJob GIOSchedulerJob;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GIOJobFunc:
|
* GIOSchedulerJobFunc:
|
||||||
* @job: a #GIOJob.
|
* @job: a #GIOSchedulerJob.
|
||||||
* @cancellable: optional #GCancellable object, %NULL to ignore.
|
* @cancellable: optional #GCancellable object, %NULL to ignore.
|
||||||
* @user_data: the data to pass to callback function
|
* @user_data: the data to pass to callback function
|
||||||
*
|
*
|
||||||
* I/O Job function.
|
* I/O Job function.
|
||||||
*
|
*
|
||||||
**/
|
**/
|
||||||
typedef void (*GIOJobFunc) (GIOJob *job,
|
typedef void (*GIOSchedulerJobFunc) (GIOSchedulerJob *job,
|
||||||
GCancellable *cancellable,
|
GCancellable *cancellable,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
|
|
||||||
/**
|
void g_io_scheduler_push_job (GIOSchedulerJobFunc job_func,
|
||||||
* GIODataFunc:
|
|
||||||
* @user_data: data to pass to the I/O function.
|
|
||||||
*
|
|
||||||
* I/O Data function.
|
|
||||||
*
|
|
||||||
**/
|
|
||||||
typedef void (*GIODataFunc) (gpointer user_data);
|
|
||||||
|
|
||||||
void g_schedule_io_job (GIOJobFunc job_func,
|
|
||||||
gpointer user_data,
|
gpointer user_data,
|
||||||
GDestroyNotify notify,
|
GDestroyNotify notify,
|
||||||
gint io_priority,
|
gint io_priority,
|
||||||
GCancellable *cancellable);
|
GCancellable *cancellable);
|
||||||
void g_cancel_all_io_jobs (void);
|
void g_io_scheduler_cancel_all_jobs (void);
|
||||||
|
gboolean g_io_scheduler_job_send_to_mainloop (GIOSchedulerJob *job,
|
||||||
void g_io_job_send_to_mainloop (GIOJob *job,
|
GSourceFunc func,
|
||||||
GIODataFunc func,
|
|
||||||
gpointer user_data,
|
gpointer user_data,
|
||||||
GDestroyNotify notify,
|
GDestroyNotify notify);
|
||||||
gboolean block);
|
void g_io_scheduler_job_send_to_mainloop_async (GIOSchedulerJob *job,
|
||||||
|
GSourceFunc func,
|
||||||
|
gpointer user_data,
|
||||||
|
GDestroyNotify notify);
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
|
@ -594,7 +594,7 @@ typedef struct {
|
|||||||
} RunInThreadData;
|
} RunInThreadData;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
run_in_thread (GIOJob *job,
|
run_in_thread (GIOSchedulerJob *job,
|
||||||
GCancellable *c,
|
GCancellable *c,
|
||||||
gpointer _data)
|
gpointer _data)
|
||||||
{
|
{
|
||||||
@ -640,7 +640,7 @@ g_simple_async_result_run_in_thread (GSimpleAsyncResult *simple,
|
|||||||
data = g_new (RunInThreadData, 1);
|
data = g_new (RunInThreadData, 1);
|
||||||
data->func = func;
|
data->func = func;
|
||||||
data->simple = g_object_ref (simple);
|
data->simple = g_object_ref (simple);
|
||||||
g_schedule_io_job (run_in_thread, data, NULL, io_priority, cancellable);
|
g_io_scheduler_push_job (run_in_thread, data, NULL, io_priority, cancellable);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user