mirror of https://github.com/OpenTTD/OpenTTD
(svn r14546) -Codechange: Unify string(cpy|cat) functions
-Doc: string(cpy|cat) functionsrelease/0.7
parent
a6df995fbb
commit
38efdc8222
|
@ -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");
|
||||||
|
|
|
@ -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, ...);
|
||||||
|
|
Loading…
Reference in New Issue