Fix mbsrtowcs(3) src param for finished string.
A mistake I made while cleaning this up the first time through. mbstrtowcs(3) sets the src param to null if it finishes the string. Change-Id: I6263646e25d9537043b7025fd1dd6ae195f365e2
This commit is contained in:
parent
36bacd237d
commit
b6cc8e00cd
|
@ -84,6 +84,7 @@ size_t mbsnrtowcs(wchar_t* dst, const char** src, size_t nmc, size_t len, mbstat
|
||||||
if (static_cast<uint8_t>((*src)[i]) < 0x80) {
|
if (static_cast<uint8_t>((*src)[i]) < 0x80) {
|
||||||
// Fast path for plain ASCII characters.
|
// Fast path for plain ASCII characters.
|
||||||
if ((*src)[i] == '\0') {
|
if ((*src)[i] == '\0') {
|
||||||
|
*src = nullptr;
|
||||||
return reset_and_return(o, state);
|
return reset_and_return(o, state);
|
||||||
}
|
}
|
||||||
r = 1;
|
r = 1;
|
||||||
|
@ -96,6 +97,7 @@ size_t mbsnrtowcs(wchar_t* dst, const char** src, size_t nmc, size_t len, mbstat
|
||||||
return reset_and_return_illegal(EILSEQ, state);
|
return reset_and_return_illegal(EILSEQ, state);
|
||||||
}
|
}
|
||||||
if (r == 0) {
|
if (r == 0) {
|
||||||
|
*src = nullptr;
|
||||||
return reset_and_return(o, state);
|
return reset_and_return(o, state);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -118,7 +120,8 @@ size_t mbsnrtowcs(wchar_t* dst, const char** src, size_t nmc, size_t len, mbstat
|
||||||
dst[o] = (*src)[i];
|
dst[o] = (*src)[i];
|
||||||
r = 1;
|
r = 1;
|
||||||
if ((*src)[i] == '\0') {
|
if ((*src)[i] == '\0') {
|
||||||
break;
|
*src = nullptr;
|
||||||
|
return reset_and_return(o, state);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
r = mbrtowc(dst + o, *src + i, nmc - i, state);
|
r = mbrtowc(dst + o, *src + i, nmc - i, state);
|
||||||
|
|
|
@ -351,7 +351,7 @@ void test_mbsrtowcs(mbstate_t* ps) {
|
||||||
// Check that we didn't clobber the rest of out.
|
// Check that we didn't clobber the rest of out.
|
||||||
ASSERT_EQ(L'x', out[3]);
|
ASSERT_EQ(L'x', out[3]);
|
||||||
// Check that valid has advanced to the end of the string.
|
// Check that valid has advanced to the end of the string.
|
||||||
ASSERT_EQ(L'\0', *valid);
|
ASSERT_EQ(nullptr, valid);
|
||||||
|
|
||||||
const char* invalid = "A" "\xc2\x20" "ef";
|
const char* invalid = "A" "\xc2\x20" "ef";
|
||||||
ASSERT_EQ(static_cast<size_t>(-1), mbsrtowcs(out, &invalid, 4, ps));
|
ASSERT_EQ(static_cast<size_t>(-1), mbsrtowcs(out, &invalid, 4, ps));
|
||||||
|
|
Loading…
Reference in New Issue