document the new binlog stats
[beanstalkd.git] / tube.c
blob2366610574bf347820c24a96dd1aecd90caac49f
1 #include <stdint.h>
2 #include <stdlib.h>
3 #include <string.h>
4 #include "dat.h"
6 struct ms tubes;
8 tube
9 make_tube(const char *name)
11 tube t;
13 t = malloc(sizeof(struct tube));
14 if (!t) return NULL;
16 t->refs = 0;
18 t->name[MAX_TUBE_NAME_LEN - 1] = '\0';
19 strncpy(t->name, name, MAX_TUBE_NAME_LEN - 1);
20 if (t->name[MAX_TUBE_NAME_LEN - 1] != '\0') twarnx("truncating tube name");
22 t->ready.cap = 0;
23 t->delay.cap = 0;
24 t->ready.len = 0;
25 t->delay.len = 0;
26 t->ready.data = NULL;
27 t->delay.data = NULL;
29 t->ready.less = job_pri_less;
30 t->delay.less = job_delay_less;
31 t->ready.rec = job_setheappos;
32 t->delay.rec = job_setheappos;
33 t->buried = (struct job) { };
34 t->buried.prev = t->buried.next = &t->buried;
35 ms_init(&t->waiting, NULL, NULL);
37 t->stat = (struct stats) {0, 0, 0, 0, 0};
38 t->using_ct = t->watching_ct = 0;
39 t->deadline_at = t->pause = 0;
41 return t;
44 static void
45 tube_free(tube t)
47 prot_remove_tube(t);
48 free(t->ready.data);
49 free(t->delay.data);
50 ms_clear(&t->waiting);
51 free(t);
54 void
55 tube_dref(tube t)
57 if (!t) return;
58 if (t->refs < 1) return twarnx("refs is zero for tube: %s", t->name);
60 --t->refs;
61 if (t->refs < 1) tube_free(t);
64 void
65 tube_iref(tube t)
67 if (!t) return;
68 ++t->refs;
71 static tube
72 make_and_insert_tube(const char *name)
74 int r;
75 tube t = NULL;
77 t = make_tube(name);
78 if (!t) return NULL;
80 /* We want this global tube list to behave like "weak" refs, so don't
81 * increment the ref count. */
82 r = ms_append(&tubes, t);
83 if (!r) return tube_dref(t), (tube) 0;
85 return t;
88 tube
89 tube_find(const char *name)
91 tube t;
92 size_t i;
94 for (i = 0; i < tubes.used; i++) {
95 t = tubes.items[i];
96 if (strncmp(t->name, name, MAX_TUBE_NAME_LEN) == 0) return t;
98 return NULL;
101 tube
102 tube_find_or_make(const char *name)
104 return tube_find(name) ? : make_and_insert_tube(name);