libguac 1.5.4
|
Provides convenience functions for manipulating strings. More...
Go to the source code of this file.
Functions | |
size_t | guac_strlcpy (char *restrict dest, const char *restrict src, size_t n) |
Copies a limited number of bytes from the given source string to the given destination buffer. | |
size_t | guac_strlcat (char *restrict dest, const char *restrict src, size_t n) |
Appends the given source string after the end of the given destination string, writing at most the given number of bytes. | |
char * | guac_strnstr (const char *haystack, const char *needle, size_t len) |
Search for the null-terminated string needle in the possibly null- terminated haystack, looking at no more than len bytes. | |
char * | guac_strdup (const char *str) |
Duplicates the given string, returning a newly-allocated string containing the same contents. | |
size_t | guac_strljoin (char *restrict dest, const char *restrict const *elements, int nmemb, const char *restrict delim, size_t n) |
Concatenates each of the given strings, separated by the given delimiter, storing the result within a destination buffer. | |
Provides convenience functions for manipulating strings.
char * guac_strdup | ( | const char * | str | ) |
Duplicates the given string, returning a newly-allocated string containing the same contents.
The provided string must be null-terminated. The size of the memory block for the newly-allocated string is only guaranteed to include enough space for the contents of the provided string, including null terminator.
The pointer returned by guac_strdup() SHOULD be freed with a subsequent call to guac_mem_free(), but MAY instead be freed with a subsequent call to free().
This function behaves identically to standard strdup(), except that NULL will be returned if the provided string is NULL.
str | The string to duplicate as a newly-allocated string. |
size_t guac_strlcat | ( | char *restrict | dest, |
const char *restrict | src, | ||
size_t | n | ||
) |
Appends the given source string after the end of the given destination string, writing at most the given number of bytes.
Both the source and destination strings MUST be null-terminated. The resulting buffer will always be null-terminated, even if doing so means that the intended string is truncated, unless the destination buffer has no space available at all. As this function always returns the length of the string it tried to create (the length of destination and source strings added together), whether truncation has occurred can be detected by comparing the return value against the size of the destination buffer. If the value returned is greater than or equal to the size of the destination buffer, then the string has been truncated.
The source and destination buffers MAY NOT overlap.
dest | The buffer which should be appended with the contents of the source string. This buffer MUST already be null-terminated and will always be null-terminated unless zero bytes are available within the buffer. |
As a safeguard against incorrectly-written code, in the event that the destination buffer is not null-terminated, this function will still stop before overrunning the buffer, instead behaving as if the length of the string in the buffer is exactly the size of the buffer. The destination buffer will remain untouched (and unterminated) in this case.
src | The source string to append to the the destination buffer. This string MUST be null-terminated. |
n | The number of bytes available within the destination buffer. If this value is not greater than zero, no bytes will be written to the destination buffer, and the destination buffer may not be null-terminated. In all other cases, the destination buffer will always be null-terminated, even if doing so means that the copied data from the source string will be truncated. |
size_t guac_strlcpy | ( | char *restrict | dest, |
const char *restrict | src, | ||
size_t | n | ||
) |
Copies a limited number of bytes from the given source string to the given destination buffer.
The resulting buffer will always be null-terminated, even if doing so means that the intended string is truncated, unless the destination buffer has no space available at all. As this function always returns the length of the string it tried to create (the length of the source string), whether truncation has occurred can be detected by comparing the return value against the size of the destination buffer. If the value returned is greater than or equal to the size of the destination buffer, then the string has been truncated.
The source and destination buffers MAY NOT overlap.
dest | The buffer which should receive the contents of the source string. This buffer will always be null terminated unless zero bytes are available within the buffer. |
src | The source string to copy into the destination buffer. This string MUST be null terminated. |
n | The number of bytes available within the destination buffer. If this value is zero, no bytes will be written to the destination buffer, and the destination buffer may not be null terminated. In all other cases, the destination buffer will always be null terminated, even if doing so means that the copied data from the source string will be truncated. |
size_t guac_strljoin | ( | char *restrict | dest, |
const char *restrict const * | elements, | ||
int | nmemb, | ||
const char *restrict | delim, | ||
size_t | n | ||
) |
Concatenates each of the given strings, separated by the given delimiter, storing the result within a destination buffer.
The number of bytes written will be no more than the given number of bytes, and the destination buffer is guaranteed to be null-terminated, even if doing so means that one or more of the intended strings are truncated or omitted from the end of the result, unless the destination buffer has no space available at all. As this function always returns the length of the string it tried to create (the length of all source strings and all delimiters added together), whether truncation has occurred can be detected by comparing the return value against the size of the destination buffer. If the value returned is greater than or equal to the size of the destination buffer, then the string has been truncated.
The source strings, delimiter string, and destination buffer MAY NOT overlap.
dest | The buffer which should receive the result of joining the given strings. This buffer will always be null terminated unless zero bytes are available within the buffer. |
elements | The elements to concatenate together, separated by the given delimiter. Each element MUST be null-terminated. |
nmemb | The number of elements within the elements array. |
delim | The delimiter to include between each pair of elements. |
n | The number of bytes available within the destination buffer. If this value is not greater than zero, no bytes will be written to the destination buffer, and the destination buffer may not be null terminated. In all other cases, the destination buffer will always be null terminated, even if doing so means that the result will be truncated. |
char * guac_strnstr | ( | const char * | haystack, |
const char * | needle, | ||
size_t | len | ||
) |
Search for the null-terminated string needle in the possibly null- terminated haystack, looking at no more than len bytes.
haystack | The string to search. It may or may not be null-terminated. Only the first len bytes are searched. |
needle | The string to look for. It must be null-terminated. |
len | The maximum number of bytes to examine in haystack. |