1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66
|
/* struct::graph - critcl - layer 0 declarations
* API general utilities
*/
#ifndef _G_UTIL_H
#define _G_UTIL_H 1
#include <tcl.h>
/* Allocation macros for common situations.
*/
#define ALLOC(type) (type *) ckalloc (sizeof (type))
#define NALLOC(n,type) (type *) ckalloc ((n) * sizeof (type))
#define REALLOC(x,n,type) (type *) ckrealloc ((char*) x, (n) * sizeof (type))
/* Assertions in general, and asserting the proper range of an array index.
*/
#undef GRAPH_DEBUG
#define GRAPH_DEBUG 1
#ifdef GRAPH_DEBUG
#define XSTR(x) #x
#define STR(x) XSTR(x)
#define RANGEOK(i,n) ((0 <= (i)) && (i < (n)))
#define ASSERT(x,msg) if (!(x)) { Tcl_Panic (msg " (" #x "), in file " __FILE__ " @line " STR(__LINE__));}
#define ASSERT_BOUNDS(i,n) ASSERT (RANGEOK(i,n),"array index out of bounds: " STR(i) " > " STR(n))
#else
#define ASSERT(x,msg)
#define ASSERT_BOUNDS(i,n)
#endif
/* .................................................. */
/* NL = Node List. Actually a list of generic pointers.
* NLQ = NL Queue. Also useable as stack.
*/
typedef struct NL *NLptr;
typedef struct NL {
NLptr next;
void* n;
} NL;
typedef struct NLQ {
NLptr start;
NLptr end;
} NLQ;
void g_nlq_init (NLQ* q);
void g_nlq_append (NLQ* q, void* n);
void g_nlq_push (NLQ* q, void* n);
void* g_nlq_pop (NLQ* q);
void* g_nlq_clear (NLQ* q);
#endif /* _G_UTIL_H */
/*
* Local Variables:
* mode: c
* c-basic-offset: 4
* fill-column: 78
* End:
*/
|