-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathDebugging.c
More file actions
106 lines (90 loc) · 1.64 KB
/
Debugging.c
File metadata and controls
106 lines (90 loc) · 1.64 KB
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
* Debugging.c
* xlogo
*
* Created by Jens Bauer on Fri Nov 21 2003.
* Copyright (c) 2003 __MyCompanyName__. All rights reserved.
*
*/
#include <stdio.h>
#include <stdlib.h>
#include "Debugging.h"
#if (defined(DEBUGFLAG) && DEBUGFLAG)
typedef struct CounterObject CounterObject;
struct CounterObject
{
CounterObject *next;
const char *name;
unsigned long count;
};
static CounterObject *g_counter_objects = NULL;
CounterObject *find_object_named(const char *name)
{
CounterObject *travel;
travel = g_counter_objects;
while(travel)
{
if(name == travel->name)
{
break;
}
travel = travel->next;
}
return(travel);
}
CounterObject *get_object_named(const char *name)
{
CounterObject *object;
object = find_object_named(name);
if(NULL == object)
{
object = malloc(sizeof(CounterObject));
if(object)
{
object->next = g_counter_objects;
object->name = name;
object->count = 0;
g_counter_objects = object;
}
}
return(object);
}
void increment_object_count(const char *name)
{
CounterObject *object;
object = get_object_named(name);
if(object)
{
object->count++;
}
}
void decrement_object_count(const char *name)
{
CounterObject *object;
object = get_object_named(name);
if(object)
{
object->count--;
}
}
unsigned long get_object_count(const char *name)
{
CounterObject *object;
object = find_object_named(name);
if(object)
{
return(object->count);
}
return(0);
}
void dump_object_count()
{
CounterObject *travel;
travel = g_counter_objects;
while(travel)
{
fprintf(stderr, "number of objects named \"%s\": %lu\n", travel->name, travel->count);
travel = travel->next;
}
}
#endif