File: util.h

package info (click to toggle)
tcllib 1.20%2Bdfsg-1
  • links: PTS
  • area: main
  • in suites: bullseye
  • size: 68,064 kB
  • sloc: tcl: 216,842; ansic: 14,250; sh: 2,846; xml: 1,766; yacc: 1,145; pascal: 881; makefile: 107; perl: 84; f90: 84; python: 33; ruby: 13; php: 11
file content (66 lines) | stat: -rw-r--r-- 1,464 bytes parent folder | download | duplicates (9)
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:
 */