f71b6b46e8
- fixed invalid, missing or additional arguments - removed all type casts from arguments - added missing (void*) typecasts for %p arguments - use inttypes defines where appropriate
104 lines
2.5 KiB
C
104 lines
2.5 KiB
C
|
|
#include <stdio.h>
|
|
#include <winpr/crt.h>
|
|
#include <winpr/file.h>
|
|
#include <winpr/path.h>
|
|
#include <winpr/tchar.h>
|
|
#include <winpr/windows.h>
|
|
|
|
static TCHAR testDirectory2File1[] = _T("TestDirectory2File1");
|
|
static TCHAR testDirectory2File2[] = _T("TestDirectory2File2");
|
|
|
|
int TestFileFindNextFile(int argc, char* argv[])
|
|
{
|
|
char* str;
|
|
int length;
|
|
BOOL status;
|
|
HANDLE hFind;
|
|
LPTSTR BasePath;
|
|
WIN32_FIND_DATA FindData;
|
|
TCHAR FilePath[PATHCCH_MAX_CCH];
|
|
|
|
str = argv[1];
|
|
|
|
#ifdef UNICODE
|
|
length = MultiByteToWideChar(CP_UTF8, 0, str, strlen(str), NULL, 0);
|
|
BasePath = (WCHAR*) malloc((length + 1) * sizeof(WCHAR));
|
|
if (!BasePath)
|
|
{
|
|
_tprintf(_T("Unable to allocate memory"));
|
|
return -1;
|
|
}
|
|
MultiByteToWideChar(CP_UTF8, 0, str, length, (LPWSTR) BasePath, length * sizeof(WCHAR));
|
|
BasePath[length] = 0;
|
|
#else
|
|
BasePath = _strdup(str);
|
|
if (!BasePath)
|
|
{
|
|
printf("Unable to allocate memory");
|
|
return -1;
|
|
}
|
|
length = strlen(BasePath);
|
|
#endif
|
|
|
|
/* Simple filter matching all files inside current directory */
|
|
|
|
CopyMemory(FilePath, BasePath, length * sizeof(TCHAR));
|
|
FilePath[length] = 0;
|
|
|
|
PathCchConvertStyle(BasePath, length, PATH_STYLE_WINDOWS);
|
|
NativePathCchAppend(FilePath, PATHCCH_MAX_CCH, _T("TestDirectory2"));
|
|
NativePathCchAppend(FilePath, PATHCCH_MAX_CCH, _T("TestDirectory2File*"));
|
|
|
|
_tprintf(_T("Finding file: %s\n"), FilePath);
|
|
|
|
hFind = FindFirstFile(FilePath, &FindData);
|
|
|
|
if (hFind == INVALID_HANDLE_VALUE)
|
|
{
|
|
_tprintf(_T("FindFirstFile failure: %s\n"), FilePath);
|
|
return -1;
|
|
}
|
|
|
|
_tprintf(_T("FindFirstFile: %s"), FindData.cFileName);
|
|
|
|
/**
|
|
* The current implementation does not enforce a particular order
|
|
*/
|
|
|
|
if ((_tcscmp(FindData.cFileName, testDirectory2File1) != 0) && (_tcscmp(FindData.cFileName, testDirectory2File2) != 0))
|
|
{
|
|
_tprintf(_T("FindFirstFile failure: Expected: %s, Actual: %s\n"),
|
|
testDirectory2File1, FindData.cFileName);
|
|
return -1;
|
|
}
|
|
|
|
status = FindNextFile(hFind, &FindData);
|
|
|
|
if (!status)
|
|
{
|
|
_tprintf(_T("FindNextFile failure: Expected: TRUE, Actual: %")_T(PRId32)_T("\n"), status);
|
|
return -1;
|
|
}
|
|
|
|
if ((_tcscmp(FindData.cFileName, testDirectory2File1) != 0) && (_tcscmp(FindData.cFileName, testDirectory2File2) != 0))
|
|
{
|
|
_tprintf(_T("FindNextFile failure: Expected: %s, Actual: %s\n"),
|
|
testDirectory2File2, FindData.cFileName);
|
|
return -1;
|
|
}
|
|
|
|
status = FindNextFile(hFind, &FindData);
|
|
|
|
if (status)
|
|
{
|
|
_tprintf(_T("FindNextFile failure: Expected: FALSE, Actual: %")_T(PRId32)_T("\n"), status);
|
|
return -1;
|
|
}
|
|
|
|
FindClose(hFind);
|
|
|
|
return 0;
|
|
}
|
|
|