libexplain
1.4.D001
|
#include <libexplain/ac/stddef.h>
#include <libexplain/ac/stdlib.h>
#include <libexplain/ac/string.h>
#include <libexplain/ac/stdio.h>
#include <libexplain/gcc_attributes.h>
Go to the source code of this file.
Functions | |
LINKAGE_HIDDEN char * | strerror (int n) |
LINKAGE_HIDDEN int | strcasecmp (const char *s1, const char *s2) |
LINKAGE_HIDDEN char * | strsignal (int n) |
const char * | explain_strsignal (int n) |
char * | explain_strendcpy (char *dst, const char *src, const char *end) |
char * | strnstr (const char *haystack, const char *needle, size_t haystack_size) |
char* explain_strendcpy | ( | char * | dst, |
const char * | src, | ||
const char * | end | ||
) |
The explain_strendcpy function is a buffer-overrun-safe replacement for strcpy, strcat, and a more efficient replacement for strlcpy and strlcat.
Unless there is no space left in the buffer (dst >= end), the result will always be NUL terminated.
dst | The position within the destination string buffer to be copied into. |
src | The string to be copied into the buffer. |
end | The end of the string buffer being copied into. In most cases this is of the form "buffer + sizeof(buffer)", a constant which may be calculated at compile time. |
strcat(strcpy(buffer, "Hello, "), "World\n");
can be safely replaced by
strendcpy(strendcpy(buffer, "Hello, ", buffer + sizeof(buffer)), "World\n", buffer + sizeof(buffer));
and overruns will be handled safely. Similarly, more complex string manipulations can be written
char buffer[100]; char *bp = buffer; bp = strendcpy(bp, "Hello, ", buffer + sizeof(buffer)); bp = strendcpy(bp, "World!\n", buffer + sizeof(buffer));
all that is required to test for an overrun is
if (bp == buffer + sizeof(buffer)) fprintf(stderr, "Overrun!\n");
On the plus side, there is only one functionto remember, not two, replacing both strcpy and strcat.
There have been some quite viable replacements for strcpy and strcat in the BSD strlcpy and strlcat functions. These functions are indeed buffer-ovrrun-safe but they suffer from doing too much work (and touching too much memory) in the case of overruns.
Code such as
strlcpy(buffer, "Hello, ", sizeof(buffer)); strlcat(buffer, "World!\n", sizeof(buffer));
suffers from O(n**2) problem, constantly re-tracing the initial portions of the buffer. In addition, in the case of overruns, the BSD versions of these functions return how big the buffer should have been. This functionality is rarely used, but still requires the src to be traversed all the way to the NUL (and it could be megabytes away) before they can return. The strendcpy function does not suffer from either of these performance problems.
const char* explain_strsignal | ( | int | n | ) |
LINKAGE_HIDDEN int strcasecmp | ( | const char * | s1, |
const char * | s2 | ||
) |
char* strnstr | ( | const char * | haystack, |
const char * | needle, | ||
size_t | haystack_size | ||
) |