/* * Return the number of bytes is the length of this string * Note: this is NOT the same as the number of unicode characters
*/ unsignedlong
ucs2_strsize(const ucs2_char_t *data, unsignedlong maxlength)
{ return ucs2_strnlen(data, maxlength/sizeof(ucs2_char_t)) * sizeof(ucs2_char_t);
}
EXPORT_SYMBOL(ucs2_strsize);
/** * ucs2_strscpy() - Copy a UCS2 string into a sized buffer. * * @dst: Pointer to the destination buffer where to copy the string to. * @src: Pointer to the source buffer where to copy the string from. * @count: Size of the destination buffer, in UCS2 (16-bit) characters. * * Like strscpy(), only for UCS2 strings. * * Copy the source string @src, or as much of it as fits, into the destination * buffer @dst. The behavior is undefined if the string buffers overlap. The * destination buffer @dst is always NUL-terminated, unless it's zero-sized. * * Return: The number of characters copied into @dst (excluding the trailing * %NUL terminator) or -E2BIG if @count is 0 or @src was truncated due to the * destination buffer being too small.
*/
ssize_t ucs2_strscpy(ucs2_char_t *dst, const ucs2_char_t *src, size_t count)
{ long res;
/* * Ensure that we have a valid amount of space. We need to store at * least one NUL-character.
*/ if (count == 0 || WARN_ON_ONCE(count > INT_MAX / sizeof(*dst))) return -E2BIG;
/* * Copy at most 'count' characters, return early if we find a * NUL-terminator.
*/ for (res = 0; res < count; res++) {
ucs2_char_t c;
c = src[res];
dst[res] = c;
if (!c) return res;
}
/* * The loop above terminated without finding a NUL-terminator, * exceeding the 'count': Enforce proper NUL-termination and return * error.
*/
dst[count - 1] = 0; return -E2BIG;
}
EXPORT_SYMBOL(ucs2_strscpy);
int
ucs2_strncmp(const ucs2_char_t *a, const ucs2_char_t *b, size_t len)
{ while (1) { if (len == 0) return 0; if (*a < *b) return -1; if (*a > *b) return 1; if (*a == 0) /* implies *b == 0 */ return 0;
a++;
b++;
len--;
}
}
EXPORT_SYMBOL(ucs2_strncmp);
/* * copy at most maxlength bytes of whole utf8 characters to dest from the * ucs2 string src. * * The return value is the number of characters copied, not including the * final NUL character.
*/ unsignedlong
ucs2_as_utf8(u8 *dest, const ucs2_char_t *src, unsignedlong maxlength)
{ unsignedint i; unsignedlong j = 0; unsignedlong limit = ucs2_strnlen(src, maxlength);
for (i = 0; maxlength && i < limit; i++) {
u16 c = src[i];
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.