diff options
author | Jakob Kaivo <jkk@ung.org> | 2019-02-08 18:42:39 -0500 |
---|---|---|
committer | Jakob Kaivo <jkk@ung.org> | 2019-02-08 18:42:39 -0500 |
commit | 7ef8a7379f7f7d09e71ccae2a0b688c3cd80423f (patch) | |
tree | 092ab0aed1769117fd7b28b8592f6f96b0e0d5af /src/string/strncat.c | |
parent | 6acf19370e8adff79cd83b257d3f04aeaf2a59dd (diff) |
merge sources into single tree
Diffstat (limited to 'src/string/strncat.c')
-rw-r--r-- | src/string/strncat.c | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/string/strncat.c b/src/string/strncat.c new file mode 100644 index 00000000..34800069 --- /dev/null +++ b/src/string/strncat.c @@ -0,0 +1,40 @@ +#include <string.h> +#include "nonstd/assert.h" + +/** concatenate bounded string **/ +char * strncat(char * restrict s1, const char * restrict s2, size_t n) +{ + char *append = NULL; + size_t i; + + ASSERT_NONNULL(s1); + ASSERT_NONNULL(s2); + ASSERT_NOOVERLAP(s1, s2, strlen(s1) + strlen(s2)); + + append = s1 + strlen(s1); + + for (i = 0; i < n; i++) { + append[i] = s2[i]; + if (append[i] == '\0') { + break; + } + } + + if (append[i - 1] != '\0') { + append[i] = '\0'; + } + + return s1; +} + +/*** +appends a copy of the frist ARGUMENT(n) bytes of the string +at ARGUMENT(s2) to the end of the string at ARGUMENT(s1). The first byte of ARGUMENT(s2) will +overwrite the terminating null character of ARGUMENT(s1). No characters after the +first CHAR(\0) will be copied. The resulting string will always be null +terminated. +***/ +/* + RETURN_ALWAYS(ARGUMENT(s1)); +STDC(1) +*/ |