Junio C Hamano | d1df574 | 2005-04-25 18:26:45 -0700 | [diff] [blame] | 1 | #ifndef STRBUF_H |
| 2 | #define STRBUF_H |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 3 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 4 | /** |
| 5 | * strbuf's are meant to be used with all the usual C string and memory |
| 6 | * APIs. Given that the length of the buffer is known, it's often better to |
| 7 | * use the mem* functions than a str* one (memchr vs. strchr e.g.). |
| 8 | * Though, one has to be careful about the fact that str* functions often |
| 9 | * stop on NULs and that strbufs may have embedded NULs. |
| 10 | * |
| 11 | * A strbuf is NUL terminated for convenience, but no function in the |
| 12 | * strbuf API actually relies on the string being free of NULs. |
| 13 | * |
| 14 | * strbufs have some invariants that are very important to keep in mind: |
| 15 | * |
Jeff King | aa07cac | 2015-01-16 04:05:10 -0500 | [diff] [blame] | 16 | * - The `buf` member is never NULL, so it can be used in any usual C |
| 17 | * string operations safely. strbuf's _have_ to be initialized either by |
| 18 | * `strbuf_init()` or by `= STRBUF_INIT` before the invariants, though. |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 19 | * |
Jeff King | aa07cac | 2015-01-16 04:05:10 -0500 | [diff] [blame] | 20 | * Do *not* assume anything on what `buf` really is (e.g. if it is |
| 21 | * allocated memory or not), use `strbuf_detach()` to unwrap a memory |
| 22 | * buffer from its strbuf shell in a safe way. That is the sole supported |
| 23 | * way. This will give you a malloced buffer that you can later `free()`. |
| 24 | * |
| 25 | * However, it is totally safe to modify anything in the string pointed by |
| 26 | * the `buf` member, between the indices `0` and `len-1` (inclusive). |
| 27 | * |
| 28 | * - The `buf` member is a byte array that has at least `len + 1` bytes |
| 29 | * allocated. The extra byte is used to store a `'\0'`, allowing the |
| 30 | * `buf` member to be a valid C-string. Every strbuf function ensure this |
| 31 | * invariant is preserved. |
| 32 | * |
| 33 | * NOTE: It is OK to "play" with the buffer directly if you work it this |
| 34 | * way: |
| 35 | * |
Jeff King | 088c9a8 | 2015-01-16 04:05:16 -0500 | [diff] [blame] | 36 | * strbuf_grow(sb, SOME_SIZE); <1> |
| 37 | * strbuf_setlen(sb, sb->len + SOME_OTHER_SIZE); |
| 38 | * |
Jeff King | aa07cac | 2015-01-16 04:05:10 -0500 | [diff] [blame] | 39 | * <1> Here, the memory array starting at `sb->buf`, and of length |
| 40 | * `strbuf_avail(sb)` is all yours, and you can be sure that |
| 41 | * `strbuf_avail(sb)` is at least `SOME_SIZE`. |
| 42 | * |
| 43 | * NOTE: `SOME_OTHER_SIZE` must be smaller or equal to `strbuf_avail(sb)`. |
| 44 | * |
| 45 | * Doing so is safe, though if it has to be done in many places, adding the |
| 46 | * missing API to the strbuf module is the way to go. |
| 47 | * |
| 48 | * WARNING: Do _not_ assume that the area that is yours is of size `alloc |
| 49 | * - 1` even if it's true in the current implementation. Alloc is somehow a |
| 50 | * "private" member that should not be messed with. Use `strbuf_avail()` |
| 51 | * instead. |
| 52 | */ |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 53 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 54 | /** |
| 55 | * Data Structures |
| 56 | * --------------- |
| 57 | */ |
| 58 | |
| 59 | /** |
| 60 | * This is the string buffer structure. The `len` member can be used to |
| 61 | * determine the current length of the string, and `buf` member provides |
| 62 | * access to the string itself. |
| 63 | */ |
Junio C Hamano | d1df574 | 2005-04-25 18:26:45 -0700 | [diff] [blame] | 64 | struct strbuf { |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 65 | size_t alloc; |
| 66 | size_t len; |
Brian Gerst | bf0f910 | 2005-05-18 08:14:09 -0400 | [diff] [blame] | 67 | char *buf; |
Junio C Hamano | d1df574 | 2005-04-25 18:26:45 -0700 | [diff] [blame] | 68 | }; |
| 69 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 70 | extern char strbuf_slopbuf[]; |
Pierre Habouzit | b315c5c | 2007-09-27 12:58:23 +0200 | [diff] [blame] | 71 | #define STRBUF_INIT { 0, 0, strbuf_slopbuf } |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 72 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 73 | /** |
Jeff King | 14e2177 | 2015-01-16 04:05:28 -0500 | [diff] [blame] | 74 | * Life Cycle Functions |
| 75 | * -------------------- |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 76 | */ |
| 77 | |
| 78 | /** |
| 79 | * Initialize the structure. The second parameter can be zero or a bigger |
| 80 | * number to allocate memory, in case you want to prevent further reallocs. |
| 81 | */ |
Pierre Habouzit | f1696ee | 2007-09-10 12:35:04 +0200 | [diff] [blame] | 82 | extern void strbuf_init(struct strbuf *, size_t); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 83 | |
| 84 | /** |
| 85 | * Release a string buffer and the memory it used. You should not use the |
| 86 | * string buffer after using this function, unless you initialize it again. |
| 87 | */ |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 88 | extern void strbuf_release(struct strbuf *); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 89 | |
| 90 | /** |
| 91 | * Detach the string from the strbuf and returns it; you now own the |
| 92 | * storage the string occupies and it is your responsibility from then on |
| 93 | * to release it with `free(3)` when you are done with it. |
| 94 | */ |
Pierre Habouzit | b315c5c | 2007-09-27 12:58:23 +0200 | [diff] [blame] | 95 | extern char *strbuf_detach(struct strbuf *, size_t *); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 96 | |
| 97 | /** |
| 98 | * Attach a string to a buffer. You should specify the string to attach, |
| 99 | * the current length of the string and the amount of allocated memory. |
| 100 | * The amount must be larger than the string length, because the string you |
| 101 | * pass is supposed to be a NUL-terminated string. This string _must_ be |
| 102 | * malloc()ed, and after attaching, the pointer cannot be relied upon |
| 103 | * anymore, and neither be free()d directly. |
| 104 | */ |
Pierre Habouzit | 917c9a7 | 2007-09-15 15:56:50 +0200 | [diff] [blame] | 105 | extern void strbuf_attach(struct strbuf *, void *, size_t, size_t); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 106 | |
| 107 | /** |
| 108 | * Swap the contents of two string buffers. |
| 109 | */ |
Nguyễn Thái Ngọc Duy | 187e290 | 2014-03-01 09:50:55 +0700 | [diff] [blame] | 110 | static inline void strbuf_swap(struct strbuf *a, struct strbuf *b) |
| 111 | { |
René Scharfe | 35d803b | 2017-01-28 22:40:58 +0100 | [diff] [blame] | 112 | SWAP(*a, *b); |
Pierre Habouzit | c76689d | 2007-09-20 00:42:12 +0200 | [diff] [blame] | 113 | } |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 114 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 115 | |
| 116 | /** |
Jeff King | 14e2177 | 2015-01-16 04:05:28 -0500 | [diff] [blame] | 117 | * Functions related to the size of the buffer |
| 118 | * ------------------------------------------- |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 119 | */ |
| 120 | |
| 121 | /** |
| 122 | * Determine the amount of allocated but unused memory. |
| 123 | */ |
Nguyễn Thái Ngọc Duy | 187e290 | 2014-03-01 09:50:55 +0700 | [diff] [blame] | 124 | static inline size_t strbuf_avail(const struct strbuf *sb) |
| 125 | { |
Pierre Habouzit | c76689d | 2007-09-20 00:42:12 +0200 | [diff] [blame] | 126 | return sb->alloc ? sb->alloc - sb->len - 1 : 0; |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 127 | } |
Junio C Hamano | a8f3e22 | 2007-09-26 02:26:06 -0700 | [diff] [blame] | 128 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 129 | /** |
| 130 | * Ensure that at least this amount of unused memory is available after |
| 131 | * `len`. This is used when you know a typical size for what you will add |
| 132 | * and want to avoid repetitive automatic resizing of the underlying buffer. |
| 133 | * This is never a needed operation, but can be critical for performance in |
| 134 | * some cases. |
| 135 | */ |
Junio C Hamano | a8f3e22 | 2007-09-26 02:26:06 -0700 | [diff] [blame] | 136 | extern void strbuf_grow(struct strbuf *, size_t); |
| 137 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 138 | /** |
| 139 | * Set the length of the buffer to a given value. This function does *not* |
| 140 | * allocate new memory, so you should not perform a `strbuf_setlen()` to a |
| 141 | * length that is larger than `len + strbuf_avail()`. `strbuf_setlen()` is |
| 142 | * just meant as a 'please fix invariants from this strbuf I just messed |
| 143 | * with'. |
| 144 | */ |
Nguyễn Thái Ngọc Duy | 187e290 | 2014-03-01 09:50:55 +0700 | [diff] [blame] | 145 | static inline void strbuf_setlen(struct strbuf *sb, size_t len) |
| 146 | { |
René Scharfe | 7141efa | 2011-04-27 19:24:50 +0200 | [diff] [blame] | 147 | if (len > (sb->alloc ? sb->alloc - 1 : 0)) |
| 148 | die("BUG: strbuf_setlen() beyond buffer"); |
Pierre Habouzit | c76689d | 2007-09-20 00:42:12 +0200 | [diff] [blame] | 149 | sb->len = len; |
| 150 | sb->buf[len] = '\0'; |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 151 | } |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 152 | |
| 153 | /** |
| 154 | * Empty the buffer by setting the size of it to zero. |
| 155 | */ |
Pierre Habouzit | b315c5c | 2007-09-27 12:58:23 +0200 | [diff] [blame] | 156 | #define strbuf_reset(sb) strbuf_setlen(sb, 0) |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 157 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 158 | |
| 159 | /** |
Jeff King | 14e2177 | 2015-01-16 04:05:28 -0500 | [diff] [blame] | 160 | * Functions related to the contents of the buffer |
| 161 | * ----------------------------------------------- |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 162 | */ |
| 163 | |
| 164 | /** |
Jeff King | d468fa2 | 2015-01-16 04:06:04 -0500 | [diff] [blame] | 165 | * Strip whitespace from the beginning (`ltrim`), end (`rtrim`), or both side |
| 166 | * (`trim`) of a string. |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 167 | */ |
Lukas Sandström | eacd6dc | 2008-07-13 20:29:18 +0200 | [diff] [blame] | 168 | extern void strbuf_trim(struct strbuf *); |
Pierre Habouzit | f1696ee | 2007-09-10 12:35:04 +0200 | [diff] [blame] | 169 | extern void strbuf_rtrim(struct strbuf *); |
Lukas Sandström | eacd6dc | 2008-07-13 20:29:18 +0200 | [diff] [blame] | 170 | extern void strbuf_ltrim(struct strbuf *); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 171 | |
| 172 | /** |
| 173 | * Replace the contents of the strbuf with a reencoded form. Returns -1 |
| 174 | * on error, 0 on success. |
| 175 | */ |
Jeff King | d4241f5 | 2014-05-22 05:30:14 -0400 | [diff] [blame] | 176 | extern int strbuf_reencode(struct strbuf *sb, const char *from, const char *to); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 177 | |
| 178 | /** |
| 179 | * Lowercase each character in the buffer using `tolower`. |
| 180 | */ |
Jeff King | ffb20ce | 2014-05-23 16:03:47 -0400 | [diff] [blame] | 181 | extern void strbuf_tolower(struct strbuf *sb); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 182 | |
| 183 | /** |
| 184 | * Compare two buffers. Returns an integer less than, equal to, or greater |
| 185 | * than zero if the first buffer is found, respectively, to be less than, |
| 186 | * to match, or be greater than the second buffer. |
| 187 | */ |
Lukas Sandström | 9b200fd | 2008-07-13 20:28:24 +0200 | [diff] [blame] | 188 | extern int strbuf_cmp(const struct strbuf *, const struct strbuf *); |
Lukas Sandström | eacd6dc | 2008-07-13 20:29:18 +0200 | [diff] [blame] | 189 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 190 | |
| 191 | /** |
Jeff King | 14e2177 | 2015-01-16 04:05:28 -0500 | [diff] [blame] | 192 | * Adding data to the buffer |
| 193 | * ------------------------- |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 194 | * |
| 195 | * NOTE: All of the functions in this section will grow the buffer as |
| 196 | * necessary. If they fail for some reason other than memory shortage and the |
| 197 | * buffer hadn't been allocated before (i.e. the `struct strbuf` was set to |
| 198 | * `STRBUF_INIT`), then they will free() it. |
| 199 | */ |
| 200 | |
| 201 | /** |
| 202 | * Add a single character to the buffer. |
| 203 | */ |
| 204 | static inline void strbuf_addch(struct strbuf *sb, int c) |
| 205 | { |
Jeff King | fec501d | 2015-04-16 04:53:56 -0400 | [diff] [blame] | 206 | if (!strbuf_avail(sb)) |
| 207 | strbuf_grow(sb, 1); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 208 | sb->buf[sb->len++] = c; |
| 209 | sb->buf[sb->len] = '\0'; |
| 210 | } |
| 211 | |
| 212 | /** |
| 213 | * Add a character the specified number of times to the buffer. |
| 214 | */ |
| 215 | extern void strbuf_addchars(struct strbuf *sb, int c, size_t n); |
| 216 | |
| 217 | /** |
| 218 | * Insert data to the given position of the buffer. The remaining contents |
| 219 | * will be shifted, not overwritten. |
| 220 | */ |
| 221 | extern void strbuf_insert(struct strbuf *, size_t pos, const void *, size_t); |
| 222 | |
| 223 | /** |
| 224 | * Remove given amount of data from a given position of the buffer. |
| 225 | */ |
| 226 | extern void strbuf_remove(struct strbuf *, size_t pos, size_t len); |
| 227 | |
| 228 | /** |
| 229 | * Remove the bytes between `pos..pos+len` and replace it with the given |
| 230 | * data. |
| 231 | */ |
| 232 | extern void strbuf_splice(struct strbuf *, size_t pos, size_t len, |
| 233 | const void *, size_t); |
| 234 | |
| 235 | /** |
| 236 | * Add a NUL-terminated string to the buffer. Each line will be prepended |
| 237 | * by a comment character and a blank. |
| 238 | */ |
| 239 | extern void strbuf_add_commented_lines(struct strbuf *out, const char *buf, size_t size); |
| 240 | |
| 241 | |
| 242 | /** |
| 243 | * Add data of given length to the buffer. |
| 244 | */ |
| 245 | extern void strbuf_add(struct strbuf *, const void *, size_t); |
| 246 | |
| 247 | /** |
| 248 | * Add a NUL-terminated string to the buffer. |
| 249 | * |
| 250 | * NOTE: This function will *always* be implemented as an inline or a macro |
| 251 | * using strlen, meaning that this is efficient to write things like: |
| 252 | * |
Jeff King | 088c9a8 | 2015-01-16 04:05:16 -0500 | [diff] [blame] | 253 | * strbuf_addstr(sb, "immediate string"); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 254 | * |
| 255 | */ |
| 256 | static inline void strbuf_addstr(struct strbuf *sb, const char *s) |
| 257 | { |
| 258 | strbuf_add(sb, s, strlen(s)); |
| 259 | } |
| 260 | |
| 261 | /** |
| 262 | * Copy the contents of another buffer at the end of the current one. |
| 263 | */ |
René Scharfe | 31471ba | 2016-07-21 18:46:44 +0200 | [diff] [blame] | 264 | extern void strbuf_addbuf(struct strbuf *sb, const struct strbuf *sb2); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 265 | |
| 266 | /** |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 267 | * This function can be used to expand a format string containing |
| 268 | * placeholders. To that end, it parses the string and calls the specified |
| 269 | * function for every percent sign found. |
| 270 | * |
| 271 | * The callback function is given a pointer to the character after the `%` |
| 272 | * and a pointer to the struct strbuf. It is expected to add the expanded |
| 273 | * version of the placeholder to the strbuf, e.g. to add a newline |
| 274 | * character if the letter `n` appears after a `%`. The function returns |
| 275 | * the length of the placeholder recognized and `strbuf_expand()` skips |
| 276 | * over it. |
| 277 | * |
| 278 | * The format `%%` is automatically expanded to a single `%` as a quoting |
| 279 | * mechanism; callers do not need to handle the `%` placeholder themselves, |
| 280 | * and the callback function will not be invoked for this placeholder. |
| 281 | * |
| 282 | * All other characters (non-percent and not skipped ones) are copied |
| 283 | * verbatim to the strbuf. If the callback returned zero, meaning that the |
| 284 | * placeholder is unknown, then the percent sign is copied, too. |
| 285 | * |
| 286 | * In order to facilitate caching and to make it possible to give |
| 287 | * parameters to the callback, `strbuf_expand()` passes a context pointer, |
| 288 | * which can be used by the programmer of the callback as she sees fit. |
| 289 | */ |
| 290 | typedef size_t (*expand_fn_t) (struct strbuf *sb, const char *placeholder, void *context); |
| 291 | extern void strbuf_expand(struct strbuf *sb, const char *format, expand_fn_t fn, void *context); |
| 292 | |
| 293 | /** |
| 294 | * Used as callback for `strbuf_expand()`, expects an array of |
| 295 | * struct strbuf_expand_dict_entry as context, i.e. pairs of |
| 296 | * placeholder and replacement string. The array needs to be |
| 297 | * terminated by an entry with placeholder set to NULL. |
| 298 | */ |
| 299 | struct strbuf_expand_dict_entry { |
| 300 | const char *placeholder; |
| 301 | const char *value; |
| 302 | }; |
| 303 | extern size_t strbuf_expand_dict_cb(struct strbuf *sb, const char *placeholder, void *context); |
| 304 | |
| 305 | /** |
| 306 | * Append the contents of one strbuf to another, quoting any |
| 307 | * percent signs ("%") into double-percents ("%%") in the |
| 308 | * destination. This is useful for literal data to be fed to either |
| 309 | * strbuf_expand or to the *printf family of functions. |
| 310 | */ |
| 311 | extern void strbuf_addbuf_percentquote(struct strbuf *dst, const struct strbuf *src); |
| 312 | |
| 313 | /** |
| 314 | * Append the given byte size as a human-readable string (i.e. 12.23 KiB, |
| 315 | * 3.50 MiB). |
| 316 | */ |
| 317 | extern void strbuf_humanise_bytes(struct strbuf *buf, off_t bytes); |
| 318 | |
| 319 | /** |
| 320 | * Add a formatted string to the buffer. |
| 321 | */ |
| 322 | __attribute__((format (printf,2,3))) |
| 323 | extern void strbuf_addf(struct strbuf *sb, const char *fmt, ...); |
| 324 | |
| 325 | /** |
| 326 | * Add a formatted string prepended by a comment character and a |
| 327 | * blank to the buffer. |
| 328 | */ |
| 329 | __attribute__((format (printf, 2, 3))) |
| 330 | extern void strbuf_commented_addf(struct strbuf *sb, const char *fmt, ...); |
| 331 | |
| 332 | __attribute__((format (printf,2,0))) |
| 333 | extern void strbuf_vaddf(struct strbuf *sb, const char *fmt, va_list ap); |
| 334 | |
| 335 | /** |
Jeff King | aa1462c | 2015-06-25 12:55:45 -0400 | [diff] [blame] | 336 | * Add the time specified by `tm`, as formatted by `strftime`. |
René Scharfe | c3fbf81 | 2017-06-15 14:29:53 +0200 | [diff] [blame] | 337 | * `tz_offset` is in decimal hhmm format, e.g. -600 means six hours west |
| 338 | * of Greenwich, and it's used to expand %z internally. However, tokens |
| 339 | * with modifiers (e.g. %Ez) are passed to `strftime`. |
Ævar Arnfjörð Bjarmason | 3b70223 | 2017-07-01 13:15:47 +0000 | [diff] [blame] | 340 | * `suppress_tz_name`, when set, expands %Z internally to the empty |
| 341 | * string rather than passing it to `strftime`. |
Jeff King | aa1462c | 2015-06-25 12:55:45 -0400 | [diff] [blame] | 342 | */ |
René Scharfe | c3fbf81 | 2017-06-15 14:29:53 +0200 | [diff] [blame] | 343 | extern void strbuf_addftime(struct strbuf *sb, const char *fmt, |
| 344 | const struct tm *tm, int tz_offset, |
Ævar Arnfjörð Bjarmason | 3b70223 | 2017-07-01 13:15:47 +0000 | [diff] [blame] | 345 | int suppress_tz_name); |
Jeff King | aa1462c | 2015-06-25 12:55:45 -0400 | [diff] [blame] | 346 | |
| 347 | /** |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 348 | * Read a given size of data from a FILE* pointer to the buffer. |
| 349 | * |
| 350 | * NOTE: The buffer is rewound if the read fails. If -1 is returned, |
| 351 | * `errno` must be consulted, like you would do for `read(3)`. |
Junio C Hamano | 1a0c8df | 2016-01-13 18:32:23 -0800 | [diff] [blame] | 352 | * `strbuf_read()`, `strbuf_read_file()` and `strbuf_getline_*()` |
| 353 | * family of functions have the same behaviour as well. |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 354 | */ |
| 355 | extern size_t strbuf_fread(struct strbuf *, size_t, FILE *); |
| 356 | |
| 357 | /** |
| 358 | * Read the contents of a given file descriptor. The third argument can be |
| 359 | * used to give a hint about the file size, to avoid reallocs. If read fails, |
| 360 | * any partial read is undone. |
| 361 | */ |
| 362 | extern ssize_t strbuf_read(struct strbuf *, int fd, size_t hint); |
| 363 | |
| 364 | /** |
Stefan Beller | b4e04fb | 2015-12-15 16:04:08 -0800 | [diff] [blame] | 365 | * Read the contents of a given file descriptor partially by using only one |
| 366 | * attempt of xread. The third argument can be used to give a hint about the |
| 367 | * file size, to avoid reallocs. Returns the number of new bytes appended to |
| 368 | * the sb. |
| 369 | */ |
| 370 | extern ssize_t strbuf_read_once(struct strbuf *, int fd, size_t hint); |
| 371 | |
| 372 | /** |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 373 | * Read the contents of a file, specified by its path. The third argument |
| 374 | * can be used to give a hint about the file size, to avoid reallocs. |
Pranit Bauva | ed008d7 | 2016-06-14 11:44:11 +0530 | [diff] [blame] | 375 | * Return the number of bytes read or a negative value if some error |
| 376 | * occurred while opening or reading the file. |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 377 | */ |
Michael Haggerty | 6c8afe4 | 2015-07-03 15:59:32 +0200 | [diff] [blame] | 378 | extern ssize_t strbuf_read_file(struct strbuf *sb, const char *path, size_t hint); |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 379 | |
| 380 | /** |
| 381 | * Read the target of a symbolic link, specified by its path. The third |
| 382 | * argument can be used to give a hint about the size, to avoid reallocs. |
| 383 | */ |
| 384 | extern int strbuf_readlink(struct strbuf *sb, const char *path, size_t hint); |
| 385 | |
| 386 | /** |
Stefan Beller | 2dac9b5 | 2016-02-29 18:07:15 -0800 | [diff] [blame] | 387 | * Write the whole content of the strbuf to the stream not stopping at |
| 388 | * NUL bytes. |
| 389 | */ |
| 390 | extern ssize_t strbuf_write(struct strbuf *sb, FILE *stream); |
| 391 | |
| 392 | /** |
Junio C Hamano | 1a0c8df | 2016-01-13 18:32:23 -0800 | [diff] [blame] | 393 | * Read a line from a FILE *, overwriting the existing contents of |
| 394 | * the strbuf. The strbuf_getline*() family of functions share |
| 395 | * this signature, but have different line termination conventions. |
| 396 | * |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 397 | * Reading stops after the terminator or at EOF. The terminator |
| 398 | * is removed from the buffer before returning. Returns 0 unless |
| 399 | * there was nothing left before EOF, in which case it returns `EOF`. |
| 400 | */ |
Junio C Hamano | 8f309ae | 2016-01-13 15:31:17 -0800 | [diff] [blame] | 401 | typedef int (*strbuf_getline_fn)(struct strbuf *, FILE *); |
| 402 | |
| 403 | /* Uses LF as the line terminator */ |
| 404 | extern int strbuf_getline_lf(struct strbuf *sb, FILE *fp); |
| 405 | |
| 406 | /* Uses NUL as the line terminator */ |
| 407 | extern int strbuf_getline_nul(struct strbuf *sb, FILE *fp); |
| 408 | |
Junio C Hamano | c8aa9fd | 2015-10-28 13:17:29 -0700 | [diff] [blame] | 409 | /* |
Junio C Hamano | 8f309ae | 2016-01-13 15:31:17 -0800 | [diff] [blame] | 410 | * Similar to strbuf_getline_lf(), but additionally treats a CR that |
| 411 | * comes immediately before the LF as part of the terminator. |
Junio C Hamano | 1a0c8df | 2016-01-13 18:32:23 -0800 | [diff] [blame] | 412 | * This is the most friendly version to be used to read "text" files |
| 413 | * that can come from platforms whose native text format is CRLF |
| 414 | * terminated. |
Junio C Hamano | c8aa9fd | 2015-10-28 13:17:29 -0700 | [diff] [blame] | 415 | */ |
Junio C Hamano | 1a0c8df | 2016-01-13 18:32:23 -0800 | [diff] [blame] | 416 | extern int strbuf_getline(struct strbuf *, FILE *); |
Junio C Hamano | c8aa9fd | 2015-10-28 13:17:29 -0700 | [diff] [blame] | 417 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 418 | |
| 419 | /** |
| 420 | * Like `strbuf_getline`, but keeps the trailing terminator (if |
| 421 | * any) in the buffer. |
| 422 | */ |
| 423 | extern int strbuf_getwholeline(struct strbuf *, FILE *, int); |
| 424 | |
| 425 | /** |
| 426 | * Like `strbuf_getwholeline`, but operates on a file descriptor. |
| 427 | * It reads one character at a time, so it is very slow. Do not |
| 428 | * use it unless you need the correct position in the file |
| 429 | * descriptor. |
| 430 | */ |
| 431 | extern int strbuf_getwholeline_fd(struct strbuf *, int, int); |
| 432 | |
| 433 | /** |
| 434 | * Set the buffer to the path of the current working directory. |
| 435 | */ |
| 436 | extern int strbuf_getcwd(struct strbuf *sb); |
| 437 | |
| 438 | /** |
| 439 | * Add a path to a buffer, converting a relative path to an |
| 440 | * absolute one in the process. Symbolic links are not |
| 441 | * resolved. |
| 442 | */ |
| 443 | extern void strbuf_add_absolute_path(struct strbuf *sb, const char *path); |
| 444 | |
René Scharfe | 33ad9dd | 2017-02-25 17:00:33 +0100 | [diff] [blame] | 445 | /** |
| 446 | * Canonize `path` (make it absolute, resolve symlinks, remove extra |
| 447 | * slashes) and append it to `sb`. Die with an informative error |
| 448 | * message if there is a problem. |
| 449 | * |
| 450 | * The directory part of `path` (i.e., everything up to the last |
| 451 | * dir_sep) must denote a valid, existing directory, but the last |
| 452 | * component need not exist. |
| 453 | * |
| 454 | * Callers that don't mind links should use the more lightweight |
| 455 | * strbuf_add_absolute_path() instead. |
| 456 | */ |
| 457 | extern void strbuf_add_real_path(struct strbuf *sb, const char *path); |
| 458 | |
Jeff King | 670c359 | 2016-10-03 16:34:17 -0400 | [diff] [blame] | 459 | |
| 460 | /** |
| 461 | * Normalize in-place the path contained in the strbuf. See |
| 462 | * normalize_path_copy() for details. If an error occurs, the contents of "sb" |
| 463 | * are left untouched, and -1 is returned. |
| 464 | */ |
| 465 | extern int strbuf_normalize_path(struct strbuf *sb); |
| 466 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 467 | /** |
| 468 | * Strip whitespace from a buffer. The second parameter controls if |
| 469 | * comments are considered contents to be removed or not. |
| 470 | */ |
Tobias Klauser | 63af4a8 | 2015-10-16 17:16:42 +0200 | [diff] [blame] | 471 | extern void strbuf_stripspace(struct strbuf *buf, int skip_comments); |
| 472 | |
| 473 | /** |
| 474 | * Temporary alias until all topic branches have switched to use |
| 475 | * strbuf_stripspace directly. |
| 476 | */ |
| 477 | static inline void stripspace(struct strbuf *buf, int skip_comments) |
| 478 | { |
| 479 | strbuf_stripspace(buf, skip_comments); |
| 480 | } |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 481 | |
Jeff King | 6dda4e6 | 2014-06-30 13:01:51 -0400 | [diff] [blame] | 482 | static inline int strbuf_strip_suffix(struct strbuf *sb, const char *suffix) |
| 483 | { |
| 484 | if (strip_suffix_mem(sb->buf, &sb->len, suffix)) { |
| 485 | strbuf_setlen(sb, sb->len); |
| 486 | return 1; |
| 487 | } else |
| 488 | return 0; |
| 489 | } |
| 490 | |
Stefan Beller | 6afbbdd | 2015-01-16 04:04:51 -0500 | [diff] [blame] | 491 | /** |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 492 | * Split str (of length slen) at the specified terminator character. |
| 493 | * Return a null-terminated array of pointers to strbuf objects |
| 494 | * holding the substrings. The substrings include the terminator, |
| 495 | * except for the last substring, which might be unterminated if the |
| 496 | * original string did not end with a terminator. If max is positive, |
| 497 | * then split the string into at most max substrings (with the last |
| 498 | * substring containing everything following the (max-1)th terminator |
| 499 | * character). |
| 500 | * |
Jeff King | f20e56e | 2015-01-16 04:05:57 -0500 | [diff] [blame] | 501 | * The most generic form is `strbuf_split_buf`, which takes an arbitrary |
| 502 | * pointer/len buffer. The `_str` variant takes a NUL-terminated string, |
| 503 | * the `_max` variant takes a strbuf, and just `strbuf_split` is a convenience |
| 504 | * wrapper to drop the `max` parameter. |
| 505 | * |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 506 | * For lighter-weight alternatives, see string_list_split() and |
| 507 | * string_list_split_in_place(). |
| 508 | */ |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 509 | extern struct strbuf **strbuf_split_buf(const char *, size_t, |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 510 | int terminator, int max); |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 511 | |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 512 | static inline struct strbuf **strbuf_split_str(const char *str, |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 513 | int terminator, int max) |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 514 | { |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 515 | return strbuf_split_buf(str, strlen(str), terminator, max); |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 516 | } |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 517 | |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 518 | static inline struct strbuf **strbuf_split_max(const struct strbuf *sb, |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 519 | int terminator, int max) |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 520 | { |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 521 | return strbuf_split_buf(sb->buf, sb->len, terminator, max); |
Jeff King | 2f1d9e2 | 2011-06-09 11:54:58 -0400 | [diff] [blame] | 522 | } |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 523 | |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 524 | static inline struct strbuf **strbuf_split(const struct strbuf *sb, |
| 525 | int terminator) |
Jeff King | 28fc3a6 | 2011-06-09 11:51:22 -0400 | [diff] [blame] | 526 | { |
Michael Haggerty | 17b73dc | 2012-11-04 07:46:53 +0100 | [diff] [blame] | 527 | return strbuf_split_max(sb, terminator, 0); |
Jeff King | 28fc3a6 | 2011-06-09 11:51:22 -0400 | [diff] [blame] | 528 | } |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 529 | |
Stefan Beller | 6afbbdd | 2015-01-16 04:04:51 -0500 | [diff] [blame] | 530 | /** |
Michael Haggerty | 06379a6 | 2012-11-04 07:46:54 +0100 | [diff] [blame] | 531 | * Free a NULL-terminated list of strbufs (for example, the return |
| 532 | * values of the strbuf_split*() functions). |
| 533 | */ |
Lukas Sandström | eacd6dc | 2008-07-13 20:29:18 +0200 | [diff] [blame] | 534 | extern void strbuf_list_free(struct strbuf **); |
Pierre Habouzit | f1696ee | 2007-09-10 12:35:04 +0200 | [diff] [blame] | 535 | |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 536 | /** |
Jeff King | af49c6d | 2015-09-24 17:05:45 -0400 | [diff] [blame] | 537 | * Add the abbreviation, as generated by find_unique_abbrev, of `sha1` to |
| 538 | * the strbuf `sb`. |
| 539 | */ |
| 540 | extern void strbuf_add_unique_abbrev(struct strbuf *sb, |
| 541 | const unsigned char *sha1, |
| 542 | int abbrev_len); |
| 543 | |
| 544 | /** |
Jeff King | bdfdaa4 | 2015-01-16 04:04:04 -0500 | [diff] [blame] | 545 | * Launch the user preferred editor to edit a file and fill the buffer |
| 546 | * with the file's contents upon the user completing their editing. The |
| 547 | * third argument can be used to set the environment which the editor is |
| 548 | * run in. If the buffer is NULL the editor is launched as usual but the |
| 549 | * file's contents are not read into the buffer upon completion. |
| 550 | */ |
| 551 | extern int launch_editor(const char *path, struct strbuf *buffer, const char *const *env); |
Pierre Habouzit | b449f4c | 2007-09-06 13:20:05 +0200 | [diff] [blame] | 552 | |
Junio C Hamano | 895680f | 2011-11-04 21:06:30 -0700 | [diff] [blame] | 553 | extern void strbuf_add_lines(struct strbuf *sb, const char *prefix, const char *buf, size_t size); |
| 554 | |
Stefan Beller | 6afbbdd | 2015-01-16 04:04:51 -0500 | [diff] [blame] | 555 | /** |
Michael Haggerty | 5963c03 | 2012-11-25 12:08:34 +0100 | [diff] [blame] | 556 | * Append s to sb, with the characters '<', '>', '&' and '"' converted |
| 557 | * into XML entities. |
| 558 | */ |
| 559 | extern void strbuf_addstr_xml_quoted(struct strbuf *sb, const char *s); |
| 560 | |
Jeff King | 399ad55 | 2015-09-24 17:05:43 -0400 | [diff] [blame] | 561 | /** |
| 562 | * "Complete" the contents of `sb` by ensuring that either it ends with the |
| 563 | * character `term`, or it is empty. This can be used, for example, |
| 564 | * to ensure that text ends with a newline, but without creating an empty |
| 565 | * blank line if there is no content in the first place. |
| 566 | */ |
| 567 | static inline void strbuf_complete(struct strbuf *sb, char term) |
| 568 | { |
| 569 | if (sb->len && sb->buf[sb->len - 1] != term) |
| 570 | strbuf_addch(sb, term); |
| 571 | } |
| 572 | |
Junio C Hamano | 895680f | 2011-11-04 21:06:30 -0700 | [diff] [blame] | 573 | static inline void strbuf_complete_line(struct strbuf *sb) |
| 574 | { |
Jeff King | 399ad55 | 2015-09-24 17:05:43 -0400 | [diff] [blame] | 575 | strbuf_complete(sb, '\n'); |
Junio C Hamano | 895680f | 2011-11-04 21:06:30 -0700 | [diff] [blame] | 576 | } |
| 577 | |
Jeff King | 0705fe2 | 2017-03-02 03:21:30 -0500 | [diff] [blame] | 578 | /* |
| 579 | * Copy "name" to "sb", expanding any special @-marks as handled by |
| 580 | * interpret_branch_name(). The result is a non-qualified branch name |
| 581 | * (so "foo" or "origin/master" instead of "refs/heads/foo" or |
| 582 | * "refs/remotes/origin/master"). |
| 583 | * |
| 584 | * Note that the resulting name may not be a syntactically valid refname. |
Jeff King | 0e9f62d | 2017-03-02 03:23:01 -0500 | [diff] [blame] | 585 | * |
| 586 | * If "allowed" is non-zero, restrict the set of allowed expansions. See |
| 587 | * interpret_branch_name() for details. |
Jeff King | 0705fe2 | 2017-03-02 03:21:30 -0500 | [diff] [blame] | 588 | */ |
Jeff King | 0e9f62d | 2017-03-02 03:23:01 -0500 | [diff] [blame] | 589 | extern void strbuf_branchname(struct strbuf *sb, const char *name, |
| 590 | unsigned allowed); |
Jeff King | 0705fe2 | 2017-03-02 03:21:30 -0500 | [diff] [blame] | 591 | |
| 592 | /* |
| 593 | * Like strbuf_branchname() above, but confirm that the result is |
| 594 | * syntactically valid to be used as a local branch name in refs/heads/. |
| 595 | * |
| 596 | * The return value is "0" if the result is valid, and "-1" otherwise. |
| 597 | */ |
Junio C Hamano | a2fab53 | 2009-03-21 14:35:51 -0700 | [diff] [blame] | 598 | extern int strbuf_check_branch_ref(struct strbuf *sb, const char *name); |
Junio C Hamano | a552de7 | 2009-03-21 13:17:30 -0700 | [diff] [blame] | 599 | |
Jeff King | c505116 | 2011-12-10 05:34:20 -0500 | [diff] [blame] | 600 | extern void strbuf_addstr_urlencode(struct strbuf *, const char *, |
| 601 | int reserved); |
René Scharfe | 679eebe | 2014-07-28 20:33:55 +0200 | [diff] [blame] | 602 | |
Nguyễn Thái Ngọc Duy | 9a0a30a | 2012-04-23 19:30:22 +0700 | [diff] [blame] | 603 | __attribute__((format (printf,1,2))) |
| 604 | extern int printf_ln(const char *fmt, ...); |
| 605 | __attribute__((format (printf,2,3))) |
| 606 | extern int fprintf_ln(FILE *fp, const char *fmt, ...); |
| 607 | |
Jeff King | 88d5a6f | 2014-05-22 05:44:09 -0400 | [diff] [blame] | 608 | char *xstrdup_tolower(const char *); |
| 609 | |
Stefan Beller | 6afbbdd | 2015-01-16 04:04:51 -0500 | [diff] [blame] | 610 | /** |
Jeff King | 30a0ddb | 2014-06-18 16:01:34 -0400 | [diff] [blame] | 611 | * Create a newly allocated string using printf format. You can do this easily |
| 612 | * with a strbuf, but this provides a shortcut to save a few lines. |
| 613 | */ |
| 614 | __attribute__((format (printf, 1, 0))) |
| 615 | char *xstrvfmt(const char *fmt, va_list ap); |
| 616 | __attribute__((format (printf, 1, 2))) |
| 617 | char *xstrfmt(const char *fmt, ...); |
| 618 | |
Junio C Hamano | d1df574 | 2005-04-25 18:26:45 -0700 | [diff] [blame] | 619 | #endif /* STRBUF_H */ |