diff options
Diffstat (limited to 'strings/strxnmov.c')
-rw-r--r-- | strings/strxnmov.c | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/strings/strxnmov.c b/strings/strxnmov.c new file mode 100644 index 00000000000..494b227209f --- /dev/null +++ b/strings/strxnmov.c @@ -0,0 +1,46 @@ +/* File : strxnmov.c + Author : Richard A. O'Keefe. + Updated: 2 June 1984 + Defines: strxnmov() + + strxnmov(dst, len, src1, ..., srcn, NullS) + moves the first len characters of the concatenation of src1,...,srcn + to dst. If there aren't that many characters, a NUL character will + be added to the end of dst to terminate it properly. This gives the + same effect as calling strxcpy(buff, src1, ..., srcn, NullS) with a + large enough buffer, and then calling strnmov(dst, buff, len). + It is just like strnmov except that it concatenates multiple sources. + Beware: the last argument should be the null character pointer. + Take VERY great care not to omit it! Also be careful to use NullS + and NOT to use 0, as on some machines 0 is not the same size as a + character pointer, or not the same bit pattern as NullS. + + Note: strxnmov is like strnmov in that it always moves EXACTLY len + characters; dst will be padded on the right with NUL characters as + needed. strxncpy does the same. strxncat, like strncat, does NOT. +*/ + +#include <global.h> +#include "m_string.h" +#include <stdarg.h> + +char *strxnmov(char *dst,uint len, const char *src, ...) +{ + va_list pvar; + char *result; + + va_start(pvar,src); + while (src != NullS) { + do if (len-- == 0) + { + va_end(pvar); + return dst; + } + while ((*dst++ = *src++) != 0); + dst--; + src = va_arg(pvar, char *); + } + for (result= dst; len-- != 0; *dst++ = 0) ; + va_end(pvar); + return result; +} |