1
0
Fork 0

(svn r14546) -Codechange: Unify string(cpy|cat) functions

-Doc: string(cpy|cat) functions
release/0.7
skidd13 2008-10-29 16:30:41 +00:00
parent a6df995fbb
commit 38efdc8222
2 changed files with 71 additions and 19 deletions

View File

@ -34,17 +34,21 @@ static int CDECL vseprintf(char *str, const char *last, const char *format, va_l
void ttd_strlcat(char *dst, const char *src, size_t size) void ttd_strlcat(char *dst, const char *src, size_t size)
{ {
assert(size > 0); assert(size > 0);
for (; size > 0 && *dst != '\0'; --size, ++dst) {} while (size > 0 && *dst != '\0') {
assert(size > 0); size--;
while (--size > 0 && *src != '\0') *dst++ = *src++; dst++;
*dst = '\0'; }
ttd_strlcpy(dst, src, size);
} }
void ttd_strlcpy(char *dst, const char *src, size_t size) void ttd_strlcpy(char *dst, const char *src, size_t size)
{ {
assert(size > 0); assert(size > 0);
while (--size > 0 && *src != '\0') *dst++ = *src++; while (--size > 0 && *src != '\0') {
*dst++ = *src++;
}
*dst = '\0'; *dst = '\0';
} }
@ -52,10 +56,11 @@ void ttd_strlcpy(char *dst, const char *src, size_t size)
char* strecat(char* dst, const char* src, const char* last) char* strecat(char* dst, const char* src, const char* last)
{ {
assert(dst <= last); assert(dst <= last);
for (; *dst != '\0'; ++dst) while (*dst != '\0') {
if (dst == last) return dst; if (dst == last) return dst;
for (; *src != '\0' && dst != last; ++dst, ++src) *dst = *src; dst++;
*dst = '\0'; }
return strecpy(dst, src, last); return strecpy(dst, src, last);
} }
@ -63,8 +68,11 @@ char* strecat(char* dst, const char* src, const char* last)
char* strecpy(char* dst, const char* src, const char* last) char* strecpy(char* dst, const char* src, const char* last)
{ {
assert(dst <= last); assert(dst <= last);
for (; *src != '\0' && dst != last; ++dst, ++src) *dst = *src; while (dst != last && *src != '\0') {
*dst++ = *src++;
}
*dst = '\0'; *dst = '\0';
if (dst == last && *src != '\0') { if (dst == last && *src != '\0') {
#ifdef STRGEN #ifdef STRGEN
error("String too long for destination buffer"); error("String too long for destination buffer");

View File

@ -22,23 +22,67 @@
#include "string_type.h" #include "string_type.h"
/** /**
* usage ttd_strlcpy(dst, src, lengthof(dst)); * Appends characters from one string to another.
* @param dst destination buffer *
* @param src string to copy/concatenate * Appends the source string to the destination string with respect of the
* @param size size of the destination buffer * terminating null-character and the maximum size of the destination
* buffer.
*
* @note usage ttd_strlcat(dst, src, lengthof(dst));
*
* @param dst The buffer containing the target string
* @param src The buffer containing the string to append
* @param size The maximum size of the destination buffer
*/ */
void ttd_strlcat(char *dst, const char *src, size_t size); void ttd_strlcat(char *dst, const char *src, size_t size);
/**
* Copies characters from one buffer to another.
*
* Copies the source string to the destination buffer with respect of the
* terminating null-character and the maximum size of the destination
* buffer.
*
* @note usage ttd_strlcpy(dst, src, lengthof(dst));
*
* @param dst The destination buffer
* @param src The buffer containing the string to copy
* @param size The maximum size of the destination buffer
*/
void ttd_strlcpy(char *dst, const char *src, size_t size); void ttd_strlcpy(char *dst, const char *src, size_t size);
/** /**
* usage: strecpy(dst, src, lastof(dst)); * Appends characters from one string to another.
* @param dst destination buffer *
* @param src string to copy * Appends the source string to the destination string with respect of the
* @param last pointer to the last element in the dst array * terminating null-character and and the last pointer to the last element
* if NULL no boundary check is performed * in the destination buffer. If the last pointer is set to NULL no
* @return a pointer to the terminating \0 in the destination buffer * boundary check is performed.
*
* @note usage: strecat(dst, src, lastof(dst));
*
* @param dst The buffer containing the target string
* @param src The buffer containing the string to append
* @param last The pointer to the last element of the destination buffer
* @return The pointer to the terminating null-character in the destination buffer
*/ */
char *strecat(char *dst, const char *src, const char *last); char *strecat(char *dst, const char *src, const char *last);
/**
* Copies characters from one buffer to another.
*
* Copies the source string to the destination buffer with respect of the
* terminating null-character and the last pointer to the last element in
* the destination buffer. If the last pointer is set to NULL no boundary
* check is performed.
*
* @note usage: strecpy(dst, src, lastof(dst));
*
* @param dst The destination buffer
* @param src The buffer containing the string to copy
* @param last The pointer to the last element of the destination buffer
* @return The pointer to the terminating null-character in the destination buffer
*/
char *strecpy(char *dst, const char *src, const char *last); char *strecpy(char *dst, const char *src, const char *last);
int CDECL seprintf(char *str, const char *last, const char *format, ...); int CDECL seprintf(char *str, const char *last, const char *format, ...);