Jo Shields a575963da9 Imported Upstream version 3.6.0
Former-commit-id: da6be194a6b1221998fc28233f2503bd61dd9d14
2014-08-13 10:39:27 +01:00

114 lines
2.4 KiB
C

/*
* gqueue.c: Queue
*
* Author:
* Duncan Mak (duncan@novell.com)
* Gonzalo Paniagua Javier (gonzalo@novell.com)
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*
* Copyright (c) 2006-2009 Novell, Inc.
*
*/
#include <stdio.h>
#include <glib.h>
gpointer
g_queue_pop_head (GQueue *queue)
{
gpointer result;
GList *old_head;
if (!queue || queue->length == 0)
return NULL;
result = queue->head->data;
old_head = queue->head;
queue->head = old_head->next;
g_list_free_1 (old_head);
if (--queue->length)
queue->head->prev = NULL;
else
queue->tail = NULL;
return result;
}
gboolean
g_queue_is_empty (GQueue *queue)
{
if (!queue)
return TRUE;
return queue->length == 0;
}
void
g_queue_push_head (GQueue *queue, gpointer head)
{
if (!queue)
return;
queue->head = g_list_prepend (queue->head, head);
if (!queue->tail)
queue->tail = queue->head;
queue->length ++;
}
void
g_queue_push_tail (GQueue *queue, gpointer data)
{
if (!queue)
return;
queue->tail = g_list_append (queue->tail, data);
if (queue->head == NULL)
queue->head = queue->tail;
else
queue->tail = queue->tail->next;
queue->length++;
}
GQueue *
g_queue_new (void)
{
return g_new0 (GQueue, 1);
}
void
g_queue_free (GQueue *queue)
{
if (!queue)
return;
g_list_free (queue->head);
g_free (queue);
}
void
g_queue_foreach (GQueue *queue, GFunc func, gpointer user_data)
{
g_list_foreach (queue->head, func, user_data);
}