221ade2472655ba842477b1249feb7ca7209631c
[samtools.git] / kstring.h
1 #ifndef KSTRING_H
2 #define KSTRING_H
3
4 #include <stdlib.h>
5 #include <string.h>
6
7 #ifndef kroundup32
8 #define kroundup32(x) (--(x), (x)|=(x)>>1, (x)|=(x)>>2, (x)|=(x)>>4, (x)|=(x)>>8, (x)|=(x)>>16, ++(x))
9 #endif
10
11 #ifndef KSTRING_T
12 #define KSTRING_T kstring_t
13 typedef struct __kstring_t {
14         size_t l, m;
15         char *s;
16 } kstring_t;
17 #endif
18
19 int ksprintf(kstring_t *s, const char *fmt, ...);
20 int ksplit_core(char *s, int delimiter, int *_max, int **_offsets);
21
22 static inline int kputsn(const char *p, int l, kstring_t *s)
23 {
24         if (s->l + l + 1 >= s->m) {
25                 s->m = s->l + l + 2;
26                 kroundup32(s->m);
27                 s->s = (char*)realloc(s->s, s->m);
28         }
29         strncpy(s->s + s->l, p, l);
30         s->l += l;
31         s->s[s->l] = 0;
32         return l;
33 }
34
35 static inline int kputs(const char *p, kstring_t *s)
36 {
37         return kputsn(p, strlen(p), s);
38 }
39
40 static inline int kputc(int c, kstring_t *s)
41 {
42         if (s->l + 1 >= s->m) {
43                 s->m = s->l + 2;
44                 kroundup32(s->m);
45                 s->s = (char*)realloc(s->s, s->m);
46         }
47         s->s[s->l++] = c;
48         s->s[s->l] = 0;
49         return c;
50 }
51
52 static inline int *ksplit(kstring_t *s, int delimiter, int *n)
53 {
54         int max = 0, *offsets = 0;
55         *n = ksplit_core(s->s, delimiter, &max, &offsets);
56         return offsets;
57 }
58
59 #endif