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