~ubuntu-branches/ubuntu/precise/igraph/precise

« back to all changes in this revision

Viewing changes to src/dqueue.h

  • Committer: Bazaar Package Importer
  • Author(s): Mathieu Malaterre
  • Date: 2009-11-16 18:12:42 UTC
  • Revision ID: james.westby@ubuntu.com-20091116181242-mzv9p5fz9uj57xd1
Tags: upstream-0.5.3
ImportĀ upstreamĀ versionĀ 0.5.3

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/* -*- mode: C -*-  */
 
2
/* 
 
3
   IGraph library.
 
4
   Copyright (C) 2007  Gabor Csardi <csardi@rmki.kfki.hu>
 
5
   MTA RMKI, Konkoly-Thege Miklos st. 29-33, Budapest 1121, Hungary
 
6
   
 
7
   This program is free software; you can redistribute it and/or modify
 
8
   it under the terms of the GNU General Public License as published by
 
9
   the Free Software Foundation; either version 2 of the License, or
 
10
   (at your option) any later version.
 
11
   
 
12
   This program is distributed in the hope that it will be useful,
 
13
   but WITHOUT ANY WARRANTY; without even the implied warranty of
 
14
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
15
   GNU General Public License for more details.
 
16
   
 
17
   You should have received a copy of the GNU General Public License
 
18
   along with this program; if not, write to the Free Software
 
19
   Foundation, Inc.,  51 Franklin Street, Fifth Floor, Boston, MA 
 
20
   02110-1301 USA
 
21
 
 
22
*/
 
23
 
 
24
/**
 
25
 * Double ended queue data type.
 
26
 * \ingroup internal
 
27
 */
 
28
 
 
29
typedef struct TYPE(igraph_dqueue) {
 
30
  BASE *begin;
 
31
  BASE *end;
 
32
  BASE *stor_begin;
 
33
  BASE *stor_end;
 
34
} TYPE(igraph_dqueue);
 
35
 
 
36
int FUNCTION(igraph_dqueue,init)    (TYPE(igraph_dqueue)* q, long int size);
 
37
void FUNCTION(igraph_dqueue,destroy) (TYPE(igraph_dqueue)* q);
 
38
igraph_bool_t FUNCTION(igraph_dqueue,empty)   (TYPE(igraph_dqueue)* q);
 
39
void FUNCTION(igraph_dqueue,clear)   (TYPE(igraph_dqueue)* q);
 
40
igraph_bool_t FUNCTION(igraph_dqueue,full)    (TYPE(igraph_dqueue)* q);
 
41
long int FUNCTION(igraph_dqueue,size)    (TYPE(igraph_dqueue)* q);
 
42
BASE FUNCTION(igraph_dqueue,pop)     (TYPE(igraph_dqueue)* q);
 
43
BASE FUNCTION(igraph_dqueue,pop_back)(TYPE(igraph_dqueue)* q);
 
44
BASE FUNCTION(igraph_dqueue,head)    (TYPE(igraph_dqueue)* q);
 
45
BASE FUNCTION(igraph_dqueue,back)    (TYPE(igraph_dqueue)* q);
 
46
int FUNCTION(igraph_dqueue,push)    (TYPE(igraph_dqueue)* q, BASE elem);