/* struct::tree - critcl - layer 0 declarations
* API general utilities
*/
#ifndef _UTIL_H
#define _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))
/* Assertions in general, and asserting the proper range of an array index.
*/
#undef TREE_DEBUG
/*#define TREE_DEBUG 1*/
#ifdef TREE_DEBUG
#define RANGEOK(i,n) ((0 <= (i)) && (i < (n)))
#define ASSERT(x,msg) if (!(x)) { Tcl_Panic (msg);}
#define ASSERT_BOUNDS(i,n) ASSERT (RANGEOK(i,n),"array index out of bounds")
#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 nlq_init (NLQ* q);
void nlq_append (NLQ* q, void* n);
void nlq_push (NLQ* q, void* n);
void* nlq_pop (NLQ* q);
void* nlq_clear (NLQ* q);
#endif /* _UTIL_H */
/*
* Local Variables:
* mode: c
* c-basic-offset: 4
* fill-column: 78
* End:
*/
syntax highlighted by Code2HTML, v. 0.9.1