You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

128 lines
4.7 KiB

  1. /* GLIB - Library of useful routines for C programming
  2. * Copyright (C) 1995-1997 Peter Mattis, Spencer Kimball and Josh MacDonald
  3. *
  4. * This library is free software; you can redistribute it and/or
  5. * modify it under the terms of the GNU Lesser General Public
  6. * License as published by the Free Software Foundation; either
  7. * version 2 of the License, or (at your option) any later version.
  8. *
  9. * This library is distributed in the hope that it will be useful,
  10. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. * Lesser General Public License for more details.
  13. *
  14. * You should have received a copy of the GNU Lesser General Public
  15. * License along with this library; if not, write to the
  16. * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  17. * Boston, MA 02111-1307, USA.
  18. */
  19. /*
  20. * Modified by the GLib Team and others 1997-2000. See the AUTHORS
  21. * file for a list of people on the GLib Team. See the ChangeLog
  22. * files for a list of changes. These files are distributed with
  23. * GLib at ftp://ftp.gtk.org/pub/gtk/.
  24. */
  25. #if defined(G_DISABLE_SINGLE_INCLUDES) && !defined (__GLIB_H_INSIDE__) && !defined (GLIB_COMPILATION)
  26. #error "Only <glib.h> can be included directly."
  27. #endif
  28. #ifndef __G_QUEUE_H__
  29. #define __G_QUEUE_H__
  30. #include <glib/glist.h>
  31. G_BEGIN_DECLS
  32. typedef struct _GQueue GQueue;
  33. struct _GQueue
  34. {
  35. GList *head;
  36. GList *tail;
  37. guint length;
  38. };
  39. #define G_QUEUE_INIT { NULL, NULL, 0 }
  40. /* Queues
  41. */
  42. GQueue* g_queue_new (void);
  43. void g_queue_free (GQueue *queue);
  44. void g_queue_init (GQueue *queue);
  45. void g_queue_clear (GQueue *queue);
  46. gboolean g_queue_is_empty (GQueue *queue);
  47. guint g_queue_get_length (GQueue *queue);
  48. void g_queue_reverse (GQueue *queue);
  49. GQueue * g_queue_copy (GQueue *queue);
  50. void g_queue_foreach (GQueue *queue,
  51. GFunc func,
  52. gpointer user_data);
  53. GList * g_queue_find (GQueue *queue,
  54. gconstpointer data);
  55. GList * g_queue_find_custom (GQueue *queue,
  56. gconstpointer data,
  57. GCompareFunc func);
  58. void g_queue_sort (GQueue *queue,
  59. GCompareDataFunc compare_func,
  60. gpointer user_data);
  61. void g_queue_push_head (GQueue *queue,
  62. gpointer data);
  63. void g_queue_push_tail (GQueue *queue,
  64. gpointer data);
  65. void g_queue_push_nth (GQueue *queue,
  66. gpointer data,
  67. gint n);
  68. gpointer g_queue_pop_head (GQueue *queue);
  69. gpointer g_queue_pop_tail (GQueue *queue);
  70. gpointer g_queue_pop_nth (GQueue *queue,
  71. guint n);
  72. gpointer g_queue_peek_head (GQueue *queue);
  73. gpointer g_queue_peek_tail (GQueue *queue);
  74. gpointer g_queue_peek_nth (GQueue *queue,
  75. guint n);
  76. gint g_queue_index (GQueue *queue,
  77. gconstpointer data);
  78. void g_queue_remove (GQueue *queue,
  79. gconstpointer data);
  80. void g_queue_remove_all (GQueue *queue,
  81. gconstpointer data);
  82. void g_queue_insert_before (GQueue *queue,
  83. GList *sibling,
  84. gpointer data);
  85. void g_queue_insert_after (GQueue *queue,
  86. GList *sibling,
  87. gpointer data);
  88. void g_queue_insert_sorted (GQueue *queue,
  89. gpointer data,
  90. GCompareDataFunc func,
  91. gpointer user_data);
  92. void g_queue_push_head_link (GQueue *queue,
  93. GList *link_);
  94. void g_queue_push_tail_link (GQueue *queue,
  95. GList *link_);
  96. void g_queue_push_nth_link (GQueue *queue,
  97. gint n,
  98. GList *link_);
  99. GList* g_queue_pop_head_link (GQueue *queue);
  100. GList* g_queue_pop_tail_link (GQueue *queue);
  101. GList* g_queue_pop_nth_link (GQueue *queue,
  102. guint n);
  103. GList* g_queue_peek_head_link (GQueue *queue);
  104. GList* g_queue_peek_tail_link (GQueue *queue);
  105. GList* g_queue_peek_nth_link (GQueue *queue,
  106. guint n);
  107. gint g_queue_link_index (GQueue *queue,
  108. GList *link_);
  109. void g_queue_unlink (GQueue *queue,
  110. GList *link_);
  111. void g_queue_delete_link (GQueue *queue,
  112. GList *link_);
  113. G_END_DECLS
  114. #endif /* __G_QUEUE_H__ */