[glib] Add g_source_get_time()



commit b7d8363fbec421d1e3e8b1a198fd7efb2ec9d2bc
Author: Ryan Lortie <desrt desrt ca>
Date:   Fri Oct 22 18:40:08 2010 +0200

    Add g_source_get_time()
    
    Cached version of g_get_monotonic_time() that does similar to what
    g_source_get_current_time() does for g_get_current_time().

 docs/reference/glib/glib-sections.txt |    1 +
 glib/glib.symbols                     |    1 +
 glib/gmain.c                          |   47 ++++++++++++++++++++++++++++++++-
 glib/gmain.h                          |    2 +
 4 files changed, 50 insertions(+), 1 deletions(-)
---
diff --git a/docs/reference/glib/glib-sections.txt b/docs/reference/glib/glib-sections.txt
index c33912c..c547c8c 100644
--- a/docs/reference/glib/glib-sections.txt
+++ b/docs/reference/glib/glib-sections.txt
@@ -535,6 +535,7 @@ GSourceFunc
 g_source_set_callback_indirect
 g_source_add_poll
 g_source_remove_poll
+g_source_get_time
 g_source_get_current_time
 g_source_remove
 g_source_remove_by_funcs_user_data
diff --git a/glib/glib.symbols b/glib/glib.symbols
index f9ae895..c499549 100644
--- a/glib/glib.symbols
+++ b/glib/glib.symbols
@@ -725,6 +725,7 @@ g_source_attach
 g_source_destroy
 g_source_get_can_recurse
 g_source_get_context
+g_source_get_time
 g_source_get_current_time
 g_source_get_id
 g_source_get_name
diff --git a/glib/gmain.c b/glib/gmain.c
index c9bd702..1428059 100644
--- a/glib/gmain.c
+++ b/glib/gmain.c
@@ -264,6 +264,8 @@ struct _GMainContext
 
   GPollFunc poll_func;
 
+  GTimeSpec time;
+  gboolean time_is_fresh;
   GTimeVal current_time;
   gboolean current_time_is_fresh;
 };
@@ -608,6 +610,7 @@ g_main_context_new (void)
   
   context->pending_dispatches = g_ptr_array_new ();
   
+  context->time_is_fresh = FALSE;
   context->current_time_is_fresh = FALSE;
   
 #ifdef G_THREADS_ENABLED
@@ -2474,6 +2477,7 @@ g_main_context_prepare (GMainContext *context,
   
   LOCK_CONTEXT (context);
 
+  context->time_is_fresh = FALSE;
   context->current_time_is_fresh = FALSE;
 
   if (context->in_check_or_prepare)
@@ -2638,7 +2642,10 @@ g_main_context_query (GMainContext *context,
     {
       *timeout = context->timeout;
       if (*timeout != 0)
-	context->current_time_is_fresh = FALSE;
+        {
+	  context->time_is_fresh = FALSE;
+	  context->current_time_is_fresh = FALSE;
+        }
     }
   
   UNLOCK_CONTEXT (context);
@@ -3386,6 +3393,44 @@ g_source_get_current_time (GSource  *source,
 }
 
 /**
+ * g_source_get_time:
+ * @source: a #GSource
+ * @timespec: #GTimeSpec structure in which to store the time
+ *
+ * Gets the time to be used when checking this source. The advantage of
+ * calling this function over calling g_get_monotonic_time() directly is
+ * that when checking multiple sources, GLib can cache a single value
+ * instead of having to repeatedly get the system monotonic time.
+ *
+ * The time here is the system monotonic time, if available, or some
+ * other reasonable alternative otherwise.  See g_get_monotonic_time().
+ *
+ * Since: 2.28
+ **/
+void
+g_source_get_time (GSource   *source,
+                   GTimeSpec *timespec)
+{
+  GMainContext *context;
+  
+  g_return_if_fail (source->context != NULL);
+ 
+  context = source->context;
+
+  LOCK_CONTEXT (context);
+
+  if (!context->time_is_fresh)
+    {
+      g_get_monotonic_time (&context->time);
+      context->time_is_fresh = TRUE;
+    }
+  
+  *timespec = context->time;
+  
+  UNLOCK_CONTEXT (context);
+}
+ 
+/**
  * g_main_context_set_poll_func:
  * @context: a #GMainContext
  * @func: the function to call to poll all file descriptors
diff --git a/glib/gmain.h b/glib/gmain.h
index eab20e7..e166f44 100644
--- a/glib/gmain.h
+++ b/glib/gmain.h
@@ -365,6 +365,8 @@ void     g_source_remove_poll      (GSource        *source,
 
 void     g_source_get_current_time (GSource        *source,
                                     GTimeVal       *timeval);
+void     g_source_get_time         (GSource        *source,
+                                    GTimeSpec      *timespec);
 
  /* void g_source_connect_closure (GSource        *source,
                                   GClosure       *closure);



[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]