curl/docs/DYNBUF.md
Daniel Stenberg f703cf971c
urlapi: leaner with fewer allocs
Slightly faster with more robust code. Uses fewer and smaller mallocs.

- remove two fields from the URL handle struct
- reduce copies and allocs
- use dynbuf buffers more instead of custom malloc + copies
- uses dynbuf to build the host name in reduces serial alloc+free within
  the same function.
- move dedotdotify into urlapi.c and make it static, not strdup the input
  and optimize it by checking for . and / before using strncmp
- remove a few strlen() calls
- add Curl_dyn_setlen() that can "trim" an existing dynbuf

Closes #9408
2022-09-07 10:21:45 +02:00

2.8 KiB

dynbuf

This is the internal module for creating and handling "dynamic buffers". This means buffers that can be appended to, dynamically and grow to adapt.

There will always be a terminating zero put at the end of the dynamic buffer.

The struct dynbuf is used to hold data for each instance of a dynamic buffer. The members of that struct MUST NOT be accessed or modified without using the dedicated dynbuf API.

init

void Curl_dyn_init(struct dynbuf *s, size_t toobig);

This inits a struct to use for dynbuf and it cannot fail. The toobig value must be set to the maximum size we allow this buffer instance to grow to. The functions below will return CURLE_OUT_OF_MEMORY when hitting this limit.

free

void Curl_dyn_free(struct dynbuf *s);

Free the associated memory and clean up. After a free, the dynbuf struct can be re-used to start appending new data to.

addn

CURLcode Curl_dyn_addn(struct dynbuf *s, const void *mem, size_t len);

Append arbitrary data of a given length to the end of the buffer.

add

CURLcode Curl_dyn_add(struct dynbuf *s, const char *str);

Append a C string to the end of the buffer.

addf

CURLcode Curl_dyn_addf(struct dynbuf *s, const char *fmt, ...);

Append a printf()-style string to the end of the buffer.

vaddf

CURLcode Curl_dyn_vaddf(struct dynbuf *s, const char *fmt, va_list ap);

Append a vprintf()-style string to the end of the buffer.

reset

void Curl_dyn_reset(struct dynbuf *s);

Reset the buffer length, but leave the allocation.

tail

CURLcode Curl_dyn_tail(struct dynbuf *s, size_t length);

Keep length bytes of the buffer tail (the last length bytes of the buffer). The rest of the buffer is dropped. The specified length must not be larger than the buffer length. To instead keep the leading part, see Curl_dyn_setlen().

ptr

char *Curl_dyn_ptr(const struct dynbuf *s);

Returns a char * to the buffer if it has a length, otherwise may return NULL. Since the buffer may be reallocated, this pointer should not be trusted or used anymore after the next buffer manipulation call.

uptr

unsigned char *Curl_dyn_uptr(const struct dynbuf *s);

Returns an unsigned char * to the buffer if it has a length, otherwise may return NULL. Since the buffer may be reallocated, this pointer should not be trusted or used anymore after the next buffer manipulation call.

len

size_t Curl_dyn_len(const struct dynbuf *s);

Returns the length of the buffer in bytes. Does not include the terminating zero byte.

setlen

CURLcode Curl_dyn_setlen(struct dynbuf *s, size_t len);

Sets the new shorter length of the buffer in number of bytes. Keeps the leftmost set number of bytes, discards the rest. To instead keep the tail part of the buffer, see Curl_dyn_tail().