int
vsscanf_l(const char * __restrict str, locale_t locale,
const char * __restrict fmt, __va_list ap)
{
FILE f = FAKE_FILE;
FIX_LOCALE(locale);
f._flags = __SRD;
f._bf._base = f._p = (unsigned char *)str;
f._bf._size = f._r = strlen(str);
f._read = eofread;
return (__svfscanf(&f, locale, fmt, ap));
}
Вот так это выглядит в моем тесте для msvc. И AppVerifier фиксирует обращение к буферу в диапазоне несуществующего 16..64 символа. Но идея была хороша...
int sscanf_my(char const* const _Buffer, _In_z_ _Scanf_s_format_string_ char const* const _Format, ...) {
va_list va;
va_start(va, _Format);
int ret = __stdio_common_vsscanf(_CRT_INTERNAL_LOCAL_SCANF_OPTIONS | _CRT_INTERNAL_SCANF_SECURECRT,
_Buffer, 64, _Format, _get_current_locale(), va);
va_end(va);
return ret;
}
int main()
{
char *mem = new char[15];
memcpy(mem, "01-01-15,00:00)", 15);
uint16_t year, month, day, hour, minute;
sscanf_my(mem, "%02hu%02hu%02hu%02hu%02hu)", &day, &month, &year, &hour, &minute);
delete[] mem;
}