[c stdlib] replace strlen/strcpy/strcmp
Use length checking versions if possible. Also replaces the wide character versions and TCHAR versions
This commit is contained in:
parent
60609251fb
commit
2e73ead996
@ -35,7 +35,7 @@ static char* append(char** buffer, size_t* size, const char* str)
|
||||
if (!resize(buffer, size, required - *size))
|
||||
return NULL;
|
||||
}
|
||||
strcat(*buffer, str);
|
||||
strncpy(&(*buffer)[len], str, add);
|
||||
return *buffer;
|
||||
}
|
||||
|
||||
|
@ -39,10 +39,12 @@ typedef CHAR TCHAR;
|
||||
#define _tprintf wprintf
|
||||
#define _sntprintf snwprintf
|
||||
#define _tcslen _wcslen
|
||||
#define _tcsnlen _wcsnlen
|
||||
#define _tcsdup _wcsdup
|
||||
#define _tcscmp wcscmp
|
||||
#define _tcsncmp wcsncmp
|
||||
#define _tcscpy wcscpy
|
||||
#define _tcsncpy wcsncpy
|
||||
#define _tcscat wcscat
|
||||
#define _tcschr wcschr
|
||||
#define _tcsrchr wcsrchr
|
||||
@ -53,10 +55,12 @@ typedef CHAR TCHAR;
|
||||
#define _tprintf printf
|
||||
#define _sntprintf snprintf
|
||||
#define _tcslen strlen
|
||||
#define _tcsnlen strnlen
|
||||
#define _tcsdup _strdup
|
||||
#define _tcscmp strcmp
|
||||
#define _tcsncmp strncmp
|
||||
#define _tcscpy strcpy
|
||||
#define _tcsncpy strncpy
|
||||
#define _tcscat strcat
|
||||
#define _tcschr strchr
|
||||
#define _tcsrchr strrchr
|
||||
|
@ -1078,15 +1078,16 @@ DWORD QueryCommDevice(LPCTSTR lpDeviceName, LPTSTR lpTargetPath, DWORD ucchMax)
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (_tcslen(storedTargetPath) + 2 > ucchMax)
|
||||
const size_t size = _tcsnlen(storedTargetPath, ucchMax);
|
||||
if (size + 2 > ucchMax)
|
||||
{
|
||||
SetLastError(ERROR_INSUFFICIENT_BUFFER);
|
||||
return 0;
|
||||
}
|
||||
|
||||
_tcscpy(lpTargetPath, storedTargetPath);
|
||||
lpTargetPath[_tcslen(storedTargetPath) + 1] = '\0'; /* 2nd final '\0' */
|
||||
return _tcslen(lpTargetPath) + 2;
|
||||
_tcsncpy(lpTargetPath, storedTargetPath, size + 1);
|
||||
lpTargetPath[size + 2] = '\0'; /* 2nd final '\0' */
|
||||
return size + 2;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -25,7 +25,6 @@
|
||||
static int test_CommDevice(LPCTSTR lpDeviceName, BOOL expectedResult)
|
||||
{
|
||||
TCHAR lpTargetPath[MAX_PATH] = { 0 };
|
||||
size_t tcslen = 0;
|
||||
|
||||
BOOL result = DefineCommDevice(lpDeviceName, _T("/dev/test"));
|
||||
if ((!expectedResult && result) || (expectedResult && !result)) /* logical XOR */
|
||||
@ -45,17 +44,18 @@ static int test_CommDevice(LPCTSTR lpDeviceName, BOOL expectedResult)
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
tcslen = (size_t)QueryCommDevice(lpDeviceName, lpTargetPath, MAX_PATH);
|
||||
const size_t tclen = QueryCommDevice(lpDeviceName, lpTargetPath, MAX_PATH);
|
||||
if (expectedResult)
|
||||
{
|
||||
if (tcslen <= _tcslen(lpTargetPath)) /* at least 2 more TCHAR are expected */
|
||||
const size_t tlen = _tcsnlen(lpTargetPath, ARRAYSIZE(lpTargetPath) - 1);
|
||||
if (tclen <= tlen) /* at least 2 more TCHAR are expected */
|
||||
{
|
||||
_tprintf(_T("QueryCommDevice failure: didn't find the device name: %s\n"),
|
||||
lpDeviceName);
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (_tcscmp(_T("/dev/test"), lpTargetPath) != 0)
|
||||
if (_tcsncmp(_T("/dev/test"), lpTargetPath, ARRAYSIZE(lpTargetPath)) != 0)
|
||||
{
|
||||
_tprintf(
|
||||
_T("QueryCommDevice failure: device name: %s, expected result: %s, result: %s\n"),
|
||||
@ -64,7 +64,7 @@ static int test_CommDevice(LPCTSTR lpDeviceName, BOOL expectedResult)
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (lpTargetPath[_tcslen(lpTargetPath) + 1] != 0)
|
||||
if ((tlen >= (ARRAYSIZE(lpTargetPath) - 1)) || (lpTargetPath[tlen + 1] != 0))
|
||||
{
|
||||
_tprintf(_T("QueryCommDevice failure: device name: %s, the second NULL character is ")
|
||||
_T("missing at the end of the buffer\n"),
|
||||
@ -74,11 +74,11 @@ static int test_CommDevice(LPCTSTR lpDeviceName, BOOL expectedResult)
|
||||
}
|
||||
else
|
||||
{
|
||||
if (tcslen > 0)
|
||||
if (tclen > 0)
|
||||
{
|
||||
_tprintf(_T("QueryCommDevice failure: device name: %s, expected result: <none>, ")
|
||||
_T("result: %") _T(PRIuz) _T(" %s\n"),
|
||||
lpDeviceName, tcslen, lpTargetPath);
|
||||
lpDeviceName, tclen, lpTargetPath);
|
||||
|
||||
return FALSE;
|
||||
}
|
||||
|
@ -7,32 +7,30 @@
|
||||
int TestEnvironmentGetEnvironmentStrings(int argc, char* argv[])
|
||||
{
|
||||
int r = -1;
|
||||
TCHAR* p = NULL;
|
||||
size_t length = 0;
|
||||
LPTCH lpszEnvironmentBlock = NULL;
|
||||
|
||||
WINPR_UNUSED(argc);
|
||||
WINPR_UNUSED(argv);
|
||||
|
||||
lpszEnvironmentBlock = GetEnvironmentStrings();
|
||||
|
||||
p = lpszEnvironmentBlock;
|
||||
LPTCH lpszEnvironmentBlock = GetEnvironmentStrings();
|
||||
if (!lpszEnvironmentBlock)
|
||||
goto fail;
|
||||
|
||||
TCHAR* p = lpszEnvironmentBlock;
|
||||
while (p[0] && p[1])
|
||||
{
|
||||
const size_t max = _tcslen(p);
|
||||
const int rc = _sntprintf(NULL, 0, _T("%s\n"), p);
|
||||
if (rc < 1)
|
||||
{
|
||||
_tprintf(_T("test failed: return %d\n"), rc);
|
||||
goto fail;
|
||||
}
|
||||
length = _tcslen(p);
|
||||
if (length != (size_t)(rc - 1))
|
||||
if (max != (size_t)(rc - 1))
|
||||
{
|
||||
_tprintf(_T("test failed: length %") _T(PRIuz) _T(" != %d [%s]\n"), length, rc - 1, p);
|
||||
_tprintf(_T("test failed: length %") _T(PRIuz) _T(" != %d [%s]\n"), max, rc - 1, p);
|
||||
goto fail;
|
||||
}
|
||||
p += (length + 1);
|
||||
p += (max + 1);
|
||||
}
|
||||
|
||||
r = 0;
|
||||
|
@ -61,8 +61,8 @@ int TestFileFindNextFile(int argc, char* argv[])
|
||||
* The current implementation does not enforce a particular order
|
||||
*/
|
||||
|
||||
if ((_tcscmp(FindData.cFileName, testDirectory2File1) != 0) &&
|
||||
(_tcscmp(FindData.cFileName, testDirectory2File2) != 0))
|
||||
if ((_tcsncmp(FindData.cFileName, testDirectory2File1, ARRAYSIZE(testDirectory2File1)) != 0) &&
|
||||
(_tcsncmp(FindData.cFileName, testDirectory2File2, ARRAYSIZE(testDirectory2File2)) != 0))
|
||||
{
|
||||
_tprintf(_T("FindFirstFile failure: Expected: %s, Actual: %s\n"), testDirectory2File1,
|
||||
FindData.cFileName);
|
||||
@ -77,8 +77,8 @@ int TestFileFindNextFile(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if ((_tcscmp(FindData.cFileName, testDirectory2File1) != 0) &&
|
||||
(_tcscmp(FindData.cFileName, testDirectory2File2) != 0))
|
||||
if ((_tcsncmp(FindData.cFileName, testDirectory2File1, ARRAYSIZE(testDirectory2File1)) != 0) &&
|
||||
(_tcsncmp(FindData.cFileName, testDirectory2File2, ARRAYSIZE(testDirectory2File2)) != 0))
|
||||
{
|
||||
_tprintf(_T("FindNextFile failure: Expected: %s, Actual: %s\n"), testDirectory2File2,
|
||||
FindData.cFileName);
|
||||
|
@ -11,7 +11,7 @@ static const TCHAR testPathNoBackslash[] = _T("C:\\Program Files");
|
||||
int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
{
|
||||
HRESULT status = 0;
|
||||
TCHAR Path[PATHCCH_MAX_CCH];
|
||||
TCHAR Path[PATHCCH_MAX_CCH] = { 0 };
|
||||
|
||||
WINPR_UNUSED(argc);
|
||||
WINPR_UNUSED(argv);
|
||||
@ -22,7 +22,7 @@ int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
* or an error code otherwise.
|
||||
*/
|
||||
|
||||
_tcscpy(Path, testPathNoBackslash);
|
||||
_tcsncpy(Path, testPathNoBackslash, ARRAYSIZE(Path));
|
||||
|
||||
/* Add a backslash to a path without a trailing backslash, expect S_OK */
|
||||
|
||||
@ -34,7 +34,7 @@ int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathBackslash) != 0)
|
||||
if (_tcsncmp(Path, testPathBackslash, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathBackslash);
|
||||
return -1;
|
||||
@ -42,7 +42,7 @@ int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
|
||||
/* Add a backslash to a path with a trailing backslash, expect S_FALSE */
|
||||
|
||||
_tcscpy(Path, testPathBackslash);
|
||||
_tcsncpy(Path, testPathBackslash, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddBackslash(Path, PATHCCH_MAX_CCH);
|
||||
|
||||
@ -52,7 +52,7 @@ int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathBackslash) != 0)
|
||||
if (_tcsncmp(Path, testPathBackslash, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathBackslash);
|
||||
return -1;
|
||||
@ -72,7 +72,7 @@ int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
|
||||
/* Use insufficient size value, expect FAILED(status) */
|
||||
|
||||
_tcscpy(Path, _T("C:\\tmp"));
|
||||
_tcsncpy(Path, _T("C:\\tmp"), ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddBackslash(Path, 7);
|
||||
|
||||
@ -86,7 +86,7 @@ int TestPathCchAddBackslash(int argc, char* argv[])
|
||||
|
||||
/* Use minimum required size value, expect S_OK */
|
||||
|
||||
_tcscpy(Path, _T("C:\\tmp"));
|
||||
_tcsncpy(Path, _T("C:\\tmp"), ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddBackslash(Path, 8);
|
||||
|
||||
|
@ -13,7 +13,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
HRESULT status = 0;
|
||||
LPTSTR pszEnd = NULL;
|
||||
size_t cchRemaining = 0;
|
||||
TCHAR Path[PATHCCH_MAX_CCH];
|
||||
TCHAR Path[PATHCCH_MAX_CCH] = { 0 };
|
||||
|
||||
WINPR_UNUSED(argc);
|
||||
WINPR_UNUSED(argv);
|
||||
@ -24,7 +24,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
* or an error code otherwise.
|
||||
*/
|
||||
|
||||
_tcscpy(Path, testPathNoBackslash);
|
||||
_tcsncpy(Path, testPathNoBackslash, ARRAYSIZE(Path));
|
||||
|
||||
/* Add a backslash to a path without a trailing backslash, expect S_OK */
|
||||
|
||||
@ -36,7 +36,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathBackslash) != 0)
|
||||
if (_tcsncmp(Path, testPathBackslash, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathBackslash);
|
||||
return -1;
|
||||
@ -44,7 +44,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
|
||||
/* Add a backslash to a path with a trailing backslash, expect S_FALSE */
|
||||
|
||||
_tcscpy(Path, testPathBackslash);
|
||||
_tcsncpy(Path, testPathBackslash, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddBackslashEx(Path, sizeof(Path) / sizeof(TCHAR), &pszEnd, &cchRemaining);
|
||||
|
||||
@ -54,7 +54,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathBackslash) != 0)
|
||||
if (_tcsncmp(Path, testPathBackslash, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathBackslash);
|
||||
return -1;
|
||||
@ -75,7 +75,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
|
||||
/* Use insufficient size value, expect FAILED(status) */
|
||||
|
||||
_tcscpy(Path, _T("C:\\tmp"));
|
||||
_tcsncpy(Path, _T("C:\\tmp"), ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddBackslashEx(Path, 7, NULL, NULL);
|
||||
|
||||
@ -89,7 +89,7 @@ int TestPathCchAddBackslashEx(int argc, char* argv[])
|
||||
|
||||
/* Use minimum required size value, expect S_OK */
|
||||
|
||||
_tcscpy(Path, _T("C:\\tmp"));
|
||||
_tcsncpy(Path, _T("C:\\tmp"), ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddBackslashEx(Path, 8, NULL, NULL);
|
||||
|
||||
|
@ -13,14 +13,14 @@ static const TCHAR testPathExtension[] = _T("C:\\Windows\\System32\\cmd.exe");
|
||||
int TestPathCchAddExtension(int argc, char* argv[])
|
||||
{
|
||||
HRESULT status = 0;
|
||||
TCHAR Path[PATHCCH_MAX_CCH];
|
||||
TCHAR Path[PATHCCH_MAX_CCH] = { 0 };
|
||||
|
||||
WINPR_UNUSED(argc);
|
||||
WINPR_UNUSED(argv);
|
||||
|
||||
/* Path: no extension, Extension: dot */
|
||||
|
||||
_tcscpy(Path, testPathNoExtension);
|
||||
_tcsncpy(Path, testPathNoExtension, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddExtension(Path, PATHCCH_MAX_CCH, testExtDot);
|
||||
|
||||
@ -30,7 +30,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathExtension) != 0)
|
||||
if (_tcsncmp(Path, testPathExtension, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathExtension);
|
||||
return -1;
|
||||
@ -38,7 +38,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
|
||||
/* Path: no extension, Extension: no dot */
|
||||
|
||||
_tcscpy(Path, testPathNoExtension);
|
||||
_tcsncpy(Path, testPathNoExtension, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddExtension(Path, PATHCCH_MAX_CCH, testExtNoDot);
|
||||
|
||||
@ -48,7 +48,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathExtension) != 0)
|
||||
if (_tcsncmp(Path, testPathExtension, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathExtension);
|
||||
return -1;
|
||||
@ -56,7 +56,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
|
||||
/* Path: extension, Extension: dot */
|
||||
|
||||
_tcscpy(Path, testPathExtension);
|
||||
_tcsncpy(Path, testPathExtension, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddExtension(Path, PATHCCH_MAX_CCH, testExtDot);
|
||||
|
||||
@ -66,7 +66,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathExtension) != 0)
|
||||
if (_tcsncmp(Path, testPathExtension, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathExtension);
|
||||
return -1;
|
||||
@ -74,7 +74,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
|
||||
/* Path: extension, Extension: no dot */
|
||||
|
||||
_tcscpy(Path, testPathExtension);
|
||||
_tcsncpy(Path, testPathExtension, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAddExtension(Path, PATHCCH_MAX_CCH, testExtDot);
|
||||
|
||||
@ -84,7 +84,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathExtension) != 0)
|
||||
if (_tcsncmp(Path, testPathExtension, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathExtension);
|
||||
return -1;
|
||||
@ -114,7 +114,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
|
||||
/* Insufficient Buffer size */
|
||||
|
||||
_tcscpy(Path, _T("C:\\456789"));
|
||||
_tcsncpy(Path, _T("C:\\456789"), ARRAYSIZE(Path));
|
||||
status = PathCchAddExtension(Path, 9 + 4, _T(".jpg"));
|
||||
if (SUCCEEDED(status))
|
||||
{
|
||||
@ -126,7 +126,7 @@ int TestPathCchAddExtension(int argc, char* argv[])
|
||||
|
||||
/* Minimum required buffer size */
|
||||
|
||||
_tcscpy(Path, _T("C:\\456789"));
|
||||
_tcsncpy(Path, _T("C:\\456789"), ARRAYSIZE(Path));
|
||||
status = PathCchAddExtension(Path, 9 + 4 + 1, _T(".jpg"));
|
||||
if (FAILED(status))
|
||||
{
|
||||
|
@ -21,7 +21,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
|
||||
/* Base Path: Backslash, More Path: No Backslash */
|
||||
|
||||
_tcscpy(Path, testBasePathBackslash);
|
||||
_tcsncpy(Path, testBasePathBackslash, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathNoBackslash);
|
||||
|
||||
@ -31,7 +31,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathOut) != 0)
|
||||
if (_tcsncmp(Path, testPathOut, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
|
||||
return -1;
|
||||
@ -39,7 +39,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
|
||||
/* Base Path: Backslash, More Path: Backslash */
|
||||
|
||||
_tcscpy(Path, testBasePathBackslash);
|
||||
_tcsncpy(Path, testBasePathBackslash, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathBackslash);
|
||||
|
||||
@ -49,7 +49,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathOut) != 0)
|
||||
if (_tcsncmp(Path, testPathOut, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
|
||||
return -1;
|
||||
@ -57,7 +57,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
|
||||
/* Base Path: No Backslash, More Path: Backslash */
|
||||
|
||||
_tcscpy(Path, testBasePathNoBackslash);
|
||||
_tcsncpy(Path, testBasePathNoBackslash, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathBackslash);
|
||||
|
||||
@ -67,7 +67,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathOut) != 0)
|
||||
if (_tcsncmp(Path, testPathOut, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
|
||||
return -1;
|
||||
@ -75,7 +75,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
|
||||
/* Base Path: No Backslash, More Path: No Backslash */
|
||||
|
||||
_tcscpy(Path, testBasePathNoBackslash);
|
||||
_tcsncpy(Path, testBasePathNoBackslash, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchAppend(Path, PATHCCH_MAX_CCH, testMorePathNoBackslash);
|
||||
|
||||
@ -85,7 +85,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathOut) != 0)
|
||||
if (_tcsncmp(Path, testPathOut, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path, testPathOut);
|
||||
return -1;
|
||||
@ -102,7 +102,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
}
|
||||
|
||||
/* According to msdn a NULL pszMore is an invalid argument (although optional !?) */
|
||||
_tcscpy(Path, testBasePathNoBackslash);
|
||||
_tcsncpy(Path, testBasePathNoBackslash, ARRAYSIZE(Path));
|
||||
status = PathCchAppend(Path, PATHCCH_MAX_CCH, NULL);
|
||||
if (status != E_INVALIDARG)
|
||||
{
|
||||
@ -113,7 +113,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
}
|
||||
|
||||
/* According to msdn cchPath must be > 0 and <= PATHCCH_MAX_CCH */
|
||||
_tcscpy(Path, testBasePathNoBackslash);
|
||||
_tcsncpy(Path, testBasePathNoBackslash, ARRAYSIZE(Path));
|
||||
status = PathCchAppend(Path, 0, testMorePathNoBackslash);
|
||||
if (status != E_INVALIDARG)
|
||||
{
|
||||
@ -122,7 +122,7 @@ int TestPathCchAppend(int argc, char* argv[])
|
||||
status);
|
||||
return -1;
|
||||
}
|
||||
_tcscpy(Path, testBasePathNoBackslash);
|
||||
_tcsncpy(Path, testBasePathNoBackslash, ARRAYSIZE(Path));
|
||||
status = PathCchAppend(Path, PATHCCH_MAX_CCH + 1, testMorePathNoBackslash);
|
||||
if (status != E_INVALIDARG)
|
||||
{
|
||||
|
@ -20,7 +20,7 @@ static const TCHAR testPathPrefixDeviceNamespace[] = _T("\\\\?\\GLOBALROOT");
|
||||
int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
{
|
||||
HRESULT status = 0;
|
||||
TCHAR Path[PATHCCH_MAX_CCH];
|
||||
TCHAR Path[PATHCCH_MAX_CCH] = { 0 };
|
||||
|
||||
WINPR_UNUSED(argc);
|
||||
WINPR_UNUSED(argv);
|
||||
@ -32,7 +32,7 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
|
||||
/* Path with prefix (File Namespace) */
|
||||
|
||||
_tcscpy(Path, testPathPrefixFileNamespace);
|
||||
_tcsncpy(Path, testPathPrefixFileNamespace, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchStripPrefix(Path, sizeof(testPathPrefixFileNamespace) / sizeof(TCHAR));
|
||||
|
||||
@ -42,7 +42,7 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathNoPrefixFileNamespace) != 0)
|
||||
if (_tcsncmp(Path, testPathNoPrefixFileNamespace, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path,
|
||||
testPathNoPrefixFileNamespace);
|
||||
@ -51,9 +51,9 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
|
||||
/* Path with prefix (Device Namespace) */
|
||||
|
||||
_tcscpy(Path, testPathPrefixDeviceNamespace);
|
||||
_tcsncpy(Path, testPathPrefixDeviceNamespace, ARRAYSIZE(Path));
|
||||
|
||||
status = PathCchStripPrefix(Path, sizeof(testPathPrefixDeviceNamespace) / sizeof(TCHAR));
|
||||
status = PathCchStripPrefix(Path, ARRAYSIZE(testPathPrefixDeviceNamespace));
|
||||
|
||||
if (status != S_FALSE)
|
||||
{
|
||||
@ -61,7 +61,7 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Path, testPathPrefixDeviceNamespace) != 0)
|
||||
if (_tcsncmp(Path, testPathPrefixDeviceNamespace, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path,
|
||||
testPathPrefixDeviceNamespace);
|
||||
@ -82,7 +82,7 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
/* Invalid cchPath values: 0, 1, 2, 3 and > PATHCCH_MAX_CCH */
|
||||
for (int i = 0; i < 5; i++)
|
||||
{
|
||||
_tcscpy(Path, testPathPrefixFileNamespace);
|
||||
_tcsncpy(Path, testPathPrefixFileNamespace, ARRAYSIZE(Path));
|
||||
if (i == 4)
|
||||
i = PATHCCH_MAX_CCH + 1;
|
||||
status = PathCchStripPrefix(Path, i);
|
||||
@ -96,8 +96,8 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
}
|
||||
|
||||
/* Minimum Path that would get successfully stripped on windows */
|
||||
_tcscpy(Path, testPathPrefixFileNamespaceMinimum);
|
||||
size_t i = sizeof(testPathPrefixFileNamespaceMinimum) / sizeof(TCHAR);
|
||||
_tcsncpy(Path, testPathPrefixFileNamespaceMinimum, ARRAYSIZE(Path));
|
||||
size_t i = ARRAYSIZE(testPathPrefixFileNamespaceMinimum);
|
||||
i = i - 1; /* include testing of a non-null terminated string */
|
||||
status = PathCchStripPrefix(Path, i);
|
||||
if (status != S_OK)
|
||||
@ -107,7 +107,7 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
status);
|
||||
return -1;
|
||||
}
|
||||
if (_tcscmp(Path, testPathNoPrefixFileNamespaceMinimum) != 0)
|
||||
if (_tcsncmp(Path, testPathNoPrefixFileNamespaceMinimum, ARRAYSIZE(Path)) != 0)
|
||||
{
|
||||
_tprintf(_T("Path Mismatch: Actual: %s, Expected: %s\n"), Path,
|
||||
testPathNoPrefixFileNamespaceMinimum);
|
||||
@ -115,7 +115,7 @@ int TestPathCchStripPrefix(int argc, char* argv[])
|
||||
}
|
||||
|
||||
/* Invalid drive letter symbol */
|
||||
_tcscpy(Path, _T("\\\\?\\5:"));
|
||||
_tcsncpy(Path, _T("\\\\?\\5:"), ARRAYSIZE(Path));
|
||||
status = PathCchStripPrefix(Path, 6);
|
||||
if (status == S_OK)
|
||||
{
|
||||
|
@ -13,14 +13,14 @@ int TestPathIsUNCEx(int argc, char* argv[])
|
||||
{
|
||||
BOOL status = 0;
|
||||
LPCTSTR Server = NULL;
|
||||
TCHAR Path[PATHCCH_MAX_CCH];
|
||||
TCHAR Path[PATHCCH_MAX_CCH] = { 0 };
|
||||
|
||||
WINPR_UNUSED(argc);
|
||||
WINPR_UNUSED(argv);
|
||||
|
||||
/* Path is UNC */
|
||||
|
||||
_tcscpy(Path, testPathUNC);
|
||||
_tcsncpy(Path, testPathUNC, ARRAYSIZE(Path));
|
||||
|
||||
status = PathIsUNCEx(Path, &Server);
|
||||
|
||||
@ -30,7 +30,7 @@ int TestPathIsUNCEx(int argc, char* argv[])
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (_tcscmp(Server, testServer) != 0)
|
||||
if (_tcsncmp(Server, testServer, ARRAYSIZE(testServer)) != 0)
|
||||
{
|
||||
_tprintf(_T("Server Name Mismatch: Actual: %s, Expected: %s\n"), Server, testServer);
|
||||
return -1;
|
||||
@ -38,7 +38,7 @@ int TestPathIsUNCEx(int argc, char* argv[])
|
||||
|
||||
/* Path is not UNC */
|
||||
|
||||
_tcscpy(Path, testPathNotUNC);
|
||||
_tcsncpy(Path, testPathNotUNC, ARRAYSIZE(Path));
|
||||
|
||||
status = PathIsUNCEx(Path, &Server);
|
||||
|
||||
|
@ -1400,7 +1400,7 @@ static KRB_CONTEXT* get_context(PCtxtHandle phContext)
|
||||
if (!name)
|
||||
return NULL;
|
||||
|
||||
if (_tcscmp(KERBEROS_SSP_NAME, name) != 0)
|
||||
if (_tcsncmp(KERBEROS_SSP_NAME, name, ARRAYSIZE(KERBEROS_SSP_NAME)) != 0)
|
||||
return NULL;
|
||||
return sspi_SecureHandleGetLowerPointer(phContext);
|
||||
}
|
||||
|
@ -604,7 +604,7 @@ static SECURITY_STATUS negotiate_mic_exchange(NEGOTIATE_CONTEXT* context, NegTok
|
||||
if (!name)
|
||||
return SEC_E_INTERNAL_ERROR;
|
||||
|
||||
if (_tcscmp(name, NTLM_SSP_NAME) == 0)
|
||||
if (_tcsncmp(name, NTLM_SSP_NAME, ARRAYSIZE(NTLM_SSP_NAME)) == 0)
|
||||
{
|
||||
if (!ntlm_reset_cipher_state(&context->sub_context))
|
||||
return SEC_E_INTERNAL_ERROR;
|
||||
@ -1407,9 +1407,9 @@ static SECURITY_STATUS SEC_ENTRY negotiate_AcquireCredentialsHandleW(
|
||||
const SecPkg* pkg = MechTable[i].pkg;
|
||||
cred->mech = &MechTable[i];
|
||||
|
||||
if (!kerberos && _tcscmp(pkg->name, KERBEROS_SSP_NAME) == 0)
|
||||
if (!kerberos && _tcsncmp(pkg->name, KERBEROS_SSP_NAME, ARRAYSIZE(KERBEROS_SSP_NAME)) == 0)
|
||||
continue;
|
||||
if (!ntlm && _tcscmp(SecPkgTable[i].name, NTLM_SSP_NAME) == 0)
|
||||
if (!ntlm && _tcsncmp(SecPkgTable[i].name, NTLM_SSP_NAME, ARRAYSIZE(NTLM_SSP_NAME)) == 0)
|
||||
continue;
|
||||
|
||||
WINPR_ASSERT(pkg->table_w);
|
||||
@ -1450,9 +1450,9 @@ static SECURITY_STATUS SEC_ENTRY negotiate_AcquireCredentialsHandleA(
|
||||
|
||||
cred->mech = &MechTable[i];
|
||||
|
||||
if (!kerberos && _tcscmp(pkg->name, KERBEROS_SSP_NAME) == 0)
|
||||
if (!kerberos && _tcsncmp(pkg->name, KERBEROS_SSP_NAME, ARRAYSIZE(KERBEROS_SSP_NAME)) == 0)
|
||||
continue;
|
||||
if (!ntlm && _tcscmp(SecPkgTable[i].name, NTLM_SSP_NAME) == 0)
|
||||
if (!ntlm && _tcsncmp(SecPkgTable[i].name, NTLM_SSP_NAME, ARRAYSIZE(NTLM_SSP_NAME)) == 0)
|
||||
continue;
|
||||
|
||||
WINPR_ASSERT(pkg->table);
|
||||
|
Loading…
Reference in New Issue
Block a user