|
1 | 1 | #ifndef STRBUF_H
|
2 | 2 | #define STRBUF_H
|
3 | 3 |
|
4 |
| -/* |
5 |
| - * Strbuf's can be use in many ways: as a byte array, or to store arbitrary |
6 |
| - * long, overflow safe strings. |
7 |
| - * |
8 |
| - * Strbufs has some invariants that are very important to keep in mind: |
9 |
| - * |
10 |
| - * 1. the ->buf member is always malloc-ed, hence strbuf's can be used to |
11 |
| - * build complex strings/buffers whose final size isn't easily known. |
12 |
| - * |
13 |
| - * It is NOT legal to copy the ->buf pointer away. |
14 |
| - * `strbuf_detach' is the operation that detaches a buffer from its shell |
15 |
| - * while keeping the shell valid wrt its invariants. |
16 |
| - * |
17 |
| - * 2. the ->buf member is a byte array that has at least ->len + 1 bytes |
18 |
| - * allocated. The extra byte is used to store a '\0', allowing the ->buf |
19 |
| - * member to be a valid C-string. Every strbuf function ensures this |
20 |
| - * invariant is preserved. |
21 |
| - * |
22 |
| - * Note that it is OK to "play" with the buffer directly if you work it |
23 |
| - * that way: |
24 |
| - * |
25 |
| - * strbuf_grow(sb, SOME_SIZE); |
26 |
| - * ... Here, the memory array starting at sb->buf, and of length |
27 |
| - * ... strbuf_avail(sb) is all yours, and you are sure that |
28 |
| - * ... strbuf_avail(sb) is at least SOME_SIZE. |
29 |
| - * strbuf_setlen(sb, sb->len + SOME_OTHER_SIZE); |
30 |
| - * |
31 |
| - * Of course, SOME_OTHER_SIZE must be smaller or equal to strbuf_avail(sb). |
32 |
| - * |
33 |
| - * Doing so is safe, though if it has to be done in many places, adding the |
34 |
| - * missing API to the strbuf module is the way to go. |
35 |
| - * |
36 |
| - * XXX: do _not_ assume that the area that is yours is of size ->alloc - 1 |
37 |
| - * even if it's true in the current implementation. Alloc is somehow a |
38 |
| - * "private" member that should not be messed with. |
39 |
| - */ |
| 4 | +/* See Documentation/technical/api-strbuf.txt */ |
40 | 5 |
|
41 | 6 | #include <assert.h>
|
42 | 7 |
|
|
0 commit comments