fix behavior of _sxprintf when a NULL buffer is supplied
fixes ntdll:string winetest
svn path=/trunk/; revision=64056
int result;
FILE stream;
- /* Check trivial case */
- if ((buffer == NULL) && (count == 0) && (sizeOfBuffer == 0))
- {
- return 0;
- }
-
#if IS_SECAPI
/* Validate parameters */
if (MSVCRT_CHECK_PMT(((buffer == NULL) || (format == NULL) || (sizeOfBuffer <= 0))))
buffer[result] = _T('\0');
#else
/* Only zero terminate if there is enough space left */
- if (stream._cnt >= sizeof(TCHAR)) *(TCHAR*)stream._ptr = _T('\0');
+ if ((stream._cnt >= sizeof(TCHAR)) && (stream._ptr))
+ *(TCHAR*)stream._ptr = _T('\0');
#endif
return result;
int
streamout_char(FILE *stream, int chr)
{
+ if ((stream->_flag & _IOSTRG) && (!stream->_ptr))
+ return 1;
+
#if defined(_USER32_WSPRINTF) || defined(_LIBCNT_)
/* Check if the buffer is full */
if (stream->_cnt < sizeof(TCHAR))