mirror of
https://github.com/Xevion/easy7zip.git
synced 2025-12-14 00:11:37 -06:00
3.13
This commit is contained in:
713
Windows/FileDir.cpp
Executable file
713
Windows/FileDir.cpp
Executable file
@@ -0,0 +1,713 @@
|
||||
// Windows/FileDir.cpp
|
||||
|
||||
#include "StdAfx.h"
|
||||
|
||||
#include "FileDir.h"
|
||||
#include "FileName.h"
|
||||
#include "FileFind.h"
|
||||
#include "Defs.h"
|
||||
#ifndef _UNICODE
|
||||
#include "../Common/StringConvert.h"
|
||||
#endif
|
||||
|
||||
namespace NWindows {
|
||||
namespace NFile {
|
||||
namespace NDirectory {
|
||||
|
||||
#ifndef _UNICODE
|
||||
static inline UINT GetCurrentCodePage()
|
||||
{ return ::AreFileApisANSI() ? CP_ACP : CP_OEMCP; }
|
||||
#endif
|
||||
|
||||
bool MyGetWindowsDirectory(CSysString &path)
|
||||
{
|
||||
DWORD needLength = ::GetWindowsDirectory(path.GetBuffer(MAX_PATH + 1), MAX_PATH + 1);
|
||||
path.ReleaseBuffer();
|
||||
return (needLength > 0 && needLength <= MAX_PATH);
|
||||
}
|
||||
|
||||
bool MyGetSystemDirectory(CSysString &path)
|
||||
{
|
||||
DWORD needLength = ::GetSystemDirectory(path.GetBuffer(MAX_PATH + 1), MAX_PATH + 1);
|
||||
path.ReleaseBuffer();
|
||||
return (needLength > 0 && needLength <= MAX_PATH);
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MyGetWindowsDirectory(UString &path)
|
||||
{
|
||||
DWORD needLength = ::GetWindowsDirectoryW(path.GetBuffer(MAX_PATH + 1), MAX_PATH + 1);
|
||||
path.ReleaseBuffer();
|
||||
if (needLength != 0)
|
||||
return (needLength <= MAX_PATH);
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
CSysString sysPath;
|
||||
if (!MyGetWindowsDirectory(sysPath))
|
||||
return false;
|
||||
path = MultiByteToUnicodeString(sysPath, GetCurrentCodePage());
|
||||
return true;
|
||||
}
|
||||
|
||||
bool MyGetSystemDirectory(UString &path)
|
||||
{
|
||||
DWORD needLength = ::GetSystemDirectoryW(path.GetBuffer(MAX_PATH + 1), MAX_PATH + 1);
|
||||
path.ReleaseBuffer();
|
||||
if (needLength != 0)
|
||||
return (needLength <= MAX_PATH);
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
CSysString sysPath;
|
||||
if (!MyGetSystemDirectory(sysPath))
|
||||
return false;
|
||||
path = MultiByteToUnicodeString(sysPath, GetCurrentCodePage());
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MySetFileAttributes(LPCWSTR fileName, DWORD fileAttributes)
|
||||
{
|
||||
if (::SetFileAttributesW(fileName, fileAttributes))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
return MySetFileAttributes(UnicodeStringToMultiByte(fileName,
|
||||
GetCurrentCodePage()), fileAttributes);
|
||||
}
|
||||
|
||||
bool MyRemoveDirectory(LPCWSTR pathName)
|
||||
{
|
||||
if (::RemoveDirectoryW(pathName))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
return MyRemoveDirectory(UnicodeStringToMultiByte(pathName,
|
||||
GetCurrentCodePage()));
|
||||
}
|
||||
|
||||
bool MyMoveFile(LPCWSTR existFileName, LPCWSTR newFileName)
|
||||
{
|
||||
if (::MoveFileW(existFileName, newFileName))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
UINT codePage = GetCurrentCodePage();
|
||||
return MyMoveFile(UnicodeStringToMultiByte(existFileName, codePage),
|
||||
UnicodeStringToMultiByte(newFileName, codePage));
|
||||
}
|
||||
#endif
|
||||
|
||||
bool MyCreateDirectory(LPCTSTR pathName)
|
||||
{
|
||||
return BOOLToBool(::CreateDirectory(pathName, NULL));
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MyCreateDirectory(LPCWSTR pathName)
|
||||
{
|
||||
if (::CreateDirectoryW(pathName, NULL))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
return MyCreateDirectory(UnicodeStringToMultiByte(pathName,
|
||||
GetCurrentCodePage()));
|
||||
}
|
||||
#endif
|
||||
|
||||
/*
|
||||
bool CreateComplexDirectory(LPCTSTR pathName)
|
||||
{
|
||||
NName::CParsedPath path;
|
||||
path.ParsePath(pathName);
|
||||
CSysString fullPath = path.Prefix;
|
||||
DWORD errorCode = ERROR_SUCCESS;
|
||||
for(int i = 0; i < path.PathParts.Size(); i++)
|
||||
{
|
||||
const CSysString &string = path.PathParts[i];
|
||||
if(string.IsEmpty())
|
||||
{
|
||||
if(i != path.PathParts.Size() - 1)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
fullPath += path.PathParts[i];
|
||||
if(!MyCreateDirectory(fullPath))
|
||||
{
|
||||
DWORD errorCode = GetLastError();
|
||||
if(errorCode != ERROR_ALREADY_EXISTS)
|
||||
return false;
|
||||
}
|
||||
fullPath += NName::kDirDelimiter;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
*/
|
||||
|
||||
bool CreateComplexDirectory(LPCTSTR _aPathName)
|
||||
{
|
||||
CSysString pathName = _aPathName;
|
||||
int pos = pathName.ReverseFind(TEXT('\\'));
|
||||
if (pos > 0 && pos == pathName.Length() - 1)
|
||||
{
|
||||
if (pathName.Length() == 3 && pathName[1] == ':')
|
||||
return true; // Disk folder;
|
||||
pathName.Delete(pos);
|
||||
}
|
||||
CSysString pathName2 = pathName;
|
||||
pos = pathName.Length();
|
||||
while(true)
|
||||
{
|
||||
if(MyCreateDirectory(pathName))
|
||||
break;
|
||||
if(::GetLastError() == ERROR_ALREADY_EXISTS)
|
||||
{
|
||||
NFind::CFileInfo fileInfo;
|
||||
if (!NFind::FindFile(pathName, fileInfo)) // For network folders
|
||||
return true;
|
||||
if (!fileInfo.IsDirectory())
|
||||
return false;
|
||||
break;
|
||||
}
|
||||
pos = pathName.ReverseFind(TEXT('\\'));
|
||||
if (pos < 0 || pos == 0)
|
||||
return false;
|
||||
if (pathName[pos - 1] == ':')
|
||||
return false;
|
||||
pathName = pathName.Left(pos);
|
||||
}
|
||||
pathName = pathName2;
|
||||
while(pos < pathName.Length())
|
||||
{
|
||||
pos = pathName.Find(TEXT('\\'), pos + 1);
|
||||
if (pos < 0)
|
||||
pos = pathName.Length();
|
||||
if(!MyCreateDirectory(pathName.Left(pos)))
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
|
||||
bool CreateComplexDirectory(LPCWSTR _aPathName)
|
||||
{
|
||||
UString pathName = _aPathName;
|
||||
int pos = pathName.ReverseFind(L'\\');
|
||||
if (pos > 0 && pos == pathName.Length() - 1)
|
||||
{
|
||||
if (pathName.Length() == 3 && pathName[1] == L':')
|
||||
return true; // Disk folder;
|
||||
pathName.Delete(pos);
|
||||
}
|
||||
UString pathName2 = pathName;
|
||||
pos = pathName.Length();
|
||||
while(true)
|
||||
{
|
||||
if(MyCreateDirectory(pathName))
|
||||
break;
|
||||
if(::GetLastError() == ERROR_ALREADY_EXISTS)
|
||||
{
|
||||
NFind::CFileInfoW fileInfo;
|
||||
if (!NFind::FindFile(pathName, fileInfo)) // For network folders
|
||||
return true;
|
||||
if (!fileInfo.IsDirectory())
|
||||
return false;
|
||||
break;
|
||||
}
|
||||
pos = pathName.ReverseFind(L'\\');
|
||||
if (pos < 0 || pos == 0)
|
||||
return false;
|
||||
if (pathName[pos - 1] == L':')
|
||||
return false;
|
||||
pathName = pathName.Left(pos);
|
||||
}
|
||||
pathName = pathName2;
|
||||
while(pos < pathName.Length())
|
||||
{
|
||||
pos = pathName.Find(L'\\', pos + 1);
|
||||
if (pos < 0)
|
||||
pos = pathName.Length();
|
||||
if(!MyCreateDirectory(pathName.Left(pos)))
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
bool DeleteFileAlways(LPCTSTR name)
|
||||
{
|
||||
if(!::SetFileAttributes(name, 0))
|
||||
return false;
|
||||
return BOOLToBool(::DeleteFile(name));
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool DeleteFileAlways(LPCWSTR name)
|
||||
{
|
||||
if(!MySetFileAttributes(name, 0))
|
||||
return false;
|
||||
if (::DeleteFileW(name))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
return DeleteFileAlways(UnicodeStringToMultiByte(name,
|
||||
GetCurrentCodePage()));
|
||||
}
|
||||
#endif
|
||||
|
||||
static bool RemoveDirectorySubItems2(const CSysString pathPrefix,
|
||||
const NFind::CFileInfo &fileInfo)
|
||||
{
|
||||
if(fileInfo.IsDirectory())
|
||||
return RemoveDirectoryWithSubItems(pathPrefix + fileInfo.Name);
|
||||
else
|
||||
return DeleteFileAlways(pathPrefix + fileInfo.Name);
|
||||
}
|
||||
|
||||
bool RemoveDirectoryWithSubItems(const CSysString &path)
|
||||
{
|
||||
NFind::CFileInfo fileInfo;
|
||||
CSysString pathPrefix = path + NName::kDirDelimiter;
|
||||
{
|
||||
NFind::CEnumerator enumerator(pathPrefix + TCHAR(NName::kAnyStringWildcard));
|
||||
while(enumerator.Next(fileInfo))
|
||||
if(!RemoveDirectorySubItems2(pathPrefix, fileInfo))
|
||||
return false;
|
||||
}
|
||||
if(!BOOLToBool(::SetFileAttributes(path, 0)))
|
||||
return false;
|
||||
return BOOLToBool(::RemoveDirectory(path));
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
static bool RemoveDirectorySubItems2(const UString pathPrefix,
|
||||
const NFind::CFileInfoW &fileInfo)
|
||||
{
|
||||
if(fileInfo.IsDirectory())
|
||||
return RemoveDirectoryWithSubItems(pathPrefix + fileInfo.Name);
|
||||
else
|
||||
return DeleteFileAlways(pathPrefix + fileInfo.Name);
|
||||
}
|
||||
bool RemoveDirectoryWithSubItems(const UString &path)
|
||||
{
|
||||
NFind::CFileInfoW fileInfo;
|
||||
UString pathPrefix = path + UString(NName::kDirDelimiter);
|
||||
{
|
||||
NFind::CEnumeratorW enumerator(pathPrefix + UString(NName::kAnyStringWildcard));
|
||||
while(enumerator.Next(fileInfo))
|
||||
if(!RemoveDirectorySubItems2(pathPrefix, fileInfo))
|
||||
return false;
|
||||
}
|
||||
if(!MySetFileAttributes(path, 0))
|
||||
return false;
|
||||
return MyRemoveDirectory(path);
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifndef _WIN32_WCE
|
||||
|
||||
bool MyGetShortPathName(LPCTSTR longPath, CSysString &shortPath)
|
||||
{
|
||||
DWORD needLength = ::GetShortPathName(longPath,
|
||||
shortPath.GetBuffer(MAX_PATH + 1), MAX_PATH + 1);
|
||||
shortPath.ReleaseBuffer();
|
||||
if (needLength == 0 || needLength >= MAX_PATH)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool MyGetFullPathName(LPCTSTR fileName, CSysString &resultPath,
|
||||
int &fileNamePartStartIndex)
|
||||
{
|
||||
LPTSTR fileNamePointer = 0;
|
||||
LPTSTR buffer = resultPath.GetBuffer(MAX_PATH);
|
||||
DWORD needLength = ::GetFullPathName(fileName, MAX_PATH + 1,
|
||||
buffer, &fileNamePointer);
|
||||
resultPath.ReleaseBuffer();
|
||||
if (needLength == 0 || needLength >= MAX_PATH)
|
||||
return false;
|
||||
if (fileNamePointer == 0)
|
||||
fileNamePartStartIndex = lstrlen(fileName);
|
||||
else
|
||||
fileNamePartStartIndex = fileNamePointer - buffer;
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MyGetFullPathName(LPCWSTR fileName, UString &resultPath,
|
||||
int &fileNamePartStartIndex)
|
||||
{
|
||||
resultPath.Empty();
|
||||
LPWSTR fileNamePointer = 0;
|
||||
LPWSTR buffer = resultPath.GetBuffer(MAX_PATH);
|
||||
DWORD needLength = ::GetFullPathNameW(fileName, MAX_PATH + 1,
|
||||
buffer, &fileNamePointer);
|
||||
resultPath.ReleaseBuffer();
|
||||
if (needLength == 0)
|
||||
{
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
|
||||
const UINT currentPage = GetCurrentCodePage();
|
||||
CSysString sysPath;
|
||||
if (!MyGetFullPathName(UnicodeStringToMultiByte(fileName,
|
||||
currentPage), sysPath, fileNamePartStartIndex))
|
||||
return false;
|
||||
UString resultPath1 = MultiByteToUnicodeString(
|
||||
sysPath.Left(fileNamePartStartIndex), currentPage);
|
||||
UString resultPath2 = MultiByteToUnicodeString(
|
||||
sysPath.Mid(fileNamePartStartIndex), currentPage);
|
||||
fileNamePartStartIndex = resultPath1.Length();
|
||||
resultPath = resultPath1 + resultPath2;
|
||||
return true;
|
||||
}
|
||||
else if (needLength >= MAX_PATH)
|
||||
return false;
|
||||
if (fileNamePointer == 0)
|
||||
fileNamePartStartIndex = MyStringLen(fileName);
|
||||
else
|
||||
fileNamePartStartIndex = fileNamePointer - buffer;
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
bool MyGetFullPathName(LPCTSTR fileName, CSysString &path)
|
||||
{
|
||||
int index;
|
||||
return MyGetFullPathName(fileName, path, index);
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MyGetFullPathName(LPCWSTR fileName, UString &path)
|
||||
{
|
||||
int index;
|
||||
return MyGetFullPathName(fileName, path, index);
|
||||
}
|
||||
#endif
|
||||
|
||||
bool GetOnlyName(LPCTSTR fileName, CSysString &resultName)
|
||||
{
|
||||
int index;
|
||||
if (!MyGetFullPathName(fileName, resultName, index))
|
||||
return false;
|
||||
resultName = resultName.Mid(index);
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool GetOnlyName(LPCWSTR fileName, UString &resultName)
|
||||
{
|
||||
int index;
|
||||
if (!MyGetFullPathName(fileName, resultName, index))
|
||||
return false;
|
||||
resultName = resultName.Mid(index);
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
bool GetOnlyDirPrefix(LPCTSTR fileName, CSysString &resultName)
|
||||
{
|
||||
int index;
|
||||
if (!MyGetFullPathName(fileName, resultName, index))
|
||||
return false;
|
||||
resultName = resultName.Left(index);
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool GetOnlyDirPrefix(LPCWSTR fileName, UString &resultName)
|
||||
{
|
||||
int index;
|
||||
if (!MyGetFullPathName(fileName, resultName, index))
|
||||
return false;
|
||||
resultName = resultName.Left(index);
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
bool MyGetCurrentDirectory(CSysString &path)
|
||||
{
|
||||
DWORD needLength = ::GetCurrentDirectory(MAX_PATH + 1,
|
||||
path.GetBuffer(MAX_PATH + 1));
|
||||
path.ReleaseBuffer();
|
||||
return (needLength > 0 && needLength <= MAX_PATH);
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MySetCurrentDirectory(LPCWSTR path)
|
||||
{
|
||||
if (::SetCurrentDirectoryW(path))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
return MySetCurrentDirectory(UnicodeStringToMultiByte(path,
|
||||
GetCurrentCodePage()));
|
||||
}
|
||||
bool MyGetCurrentDirectory(UString &path)
|
||||
{
|
||||
DWORD needLength = ::GetCurrentDirectoryW(MAX_PATH + 1,
|
||||
path.GetBuffer(MAX_PATH + 1));
|
||||
path.ReleaseBuffer();
|
||||
if (needLength != 0)
|
||||
return (needLength <= MAX_PATH);
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
CSysString sysPath;
|
||||
if (!MyGetCurrentDirectory(sysPath))
|
||||
return false;
|
||||
path = MultiByteToUnicodeString(sysPath, GetCurrentCodePage());
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
bool MySearchPath(LPCTSTR path, LPCTSTR fileName, LPCTSTR extension,
|
||||
CSysString &resultPath, UINT32 &filePart)
|
||||
{
|
||||
LPTSTR filePartPointer;
|
||||
DWORD value = ::SearchPath(path, fileName, extension,
|
||||
MAX_PATH, resultPath.GetBuffer(MAX_PATH), &filePartPointer);
|
||||
filePart = filePartPointer - (LPCTSTR)resultPath;
|
||||
resultPath.ReleaseBuffer();
|
||||
if (value == 0 || value > MAX_PATH)
|
||||
return false;
|
||||
return true;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MySearchPath(LPCWSTR path, LPCWSTR fileName, LPCWSTR extension,
|
||||
UString &resultPath, UINT32 &filePart)
|
||||
{
|
||||
LPWSTR filePartPointer = 0;
|
||||
DWORD value = ::SearchPathW(path, fileName, extension,
|
||||
MAX_PATH, resultPath.GetBuffer(MAX_PATH), &filePartPointer);
|
||||
resultPath.ReleaseBuffer();
|
||||
if (value != 0)
|
||||
return (value <= MAX_PATH);
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
|
||||
const UINT currentPage = GetCurrentCodePage();
|
||||
CSysString sysPath;
|
||||
if (!MySearchPath(
|
||||
path != 0 ? (LPCTSTR)UnicodeStringToMultiByte(path, currentPage): 0,
|
||||
fileName != 0 ? (LPCTSTR)UnicodeStringToMultiByte(fileName, currentPage): 0,
|
||||
extension != 0 ? (LPCTSTR)UnicodeStringToMultiByte(extension, currentPage): 0,
|
||||
sysPath, filePart))
|
||||
return false;
|
||||
UString resultPath1 = MultiByteToUnicodeString(
|
||||
sysPath.Left(filePart), currentPage);
|
||||
UString resultPath2 = MultiByteToUnicodeString(
|
||||
sysPath.Mid(filePart), currentPage);
|
||||
filePart = resultPath1.Length();
|
||||
resultPath = resultPath1 + resultPath2;
|
||||
return true;
|
||||
}
|
||||
#endif
|
||||
|
||||
bool MyGetTempPath(CSysString &path)
|
||||
{
|
||||
DWORD needLength = ::GetTempPath(MAX_PATH + 1,
|
||||
path.GetBuffer(MAX_PATH));
|
||||
path.ReleaseBuffer();
|
||||
return (needLength > 0 && needLength <= MAX_PATH);
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
bool MyGetTempPath(UString &path)
|
||||
{
|
||||
path.Empty();
|
||||
DWORD needLength = ::GetTempPathW(MAX_PATH + 1,
|
||||
path.GetBuffer(MAX_PATH));
|
||||
path.ReleaseBuffer();
|
||||
if (needLength == 0)
|
||||
{
|
||||
if (::GetLastError() != ERROR_CALL_NOT_IMPLEMENTED)
|
||||
return false;
|
||||
CSysString sysPath;
|
||||
if (!MyGetTempPath(sysPath))
|
||||
return false;
|
||||
path = MultiByteToUnicodeString(sysPath, GetCurrentCodePage());
|
||||
return true;
|
||||
}
|
||||
return (needLength > 0 && needLength <= MAX_PATH);
|
||||
}
|
||||
#endif
|
||||
|
||||
UINT MyGetTempFileName(LPCTSTR dirPath, LPCTSTR prefix, CSysString &path)
|
||||
{
|
||||
UINT number = ::GetTempFileName(dirPath, prefix, 0,
|
||||
path.GetBuffer(MAX_PATH));
|
||||
path.ReleaseBuffer();
|
||||
return number;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
UINT MyGetTempFileName(LPCWSTR dirPath, LPCWSTR prefix, UString &path)
|
||||
{
|
||||
UINT number = ::GetTempFileNameW(dirPath, prefix, 0,
|
||||
path.GetBuffer(MAX_PATH));
|
||||
path.ReleaseBuffer();
|
||||
if (number == 0)
|
||||
{
|
||||
if (::GetLastError() == ERROR_CALL_NOT_IMPLEMENTED)
|
||||
{
|
||||
const UINT currentPage = GetCurrentCodePage();
|
||||
CSysString sysPath;
|
||||
number = MyGetTempFileName(
|
||||
dirPath ? (LPCTSTR)UnicodeStringToMultiByte(dirPath, currentPage): 0,
|
||||
prefix ? (LPCTSTR)UnicodeStringToMultiByte(prefix, currentPage): 0,
|
||||
sysPath);
|
||||
path = MultiByteToUnicodeString(sysPath, currentPage);
|
||||
}
|
||||
}
|
||||
return number;
|
||||
}
|
||||
#endif
|
||||
|
||||
UINT CTempFile::Create(LPCTSTR dirPath, LPCTSTR prefix, CSysString &resultPath)
|
||||
{
|
||||
Remove();
|
||||
UINT number = MyGetTempFileName(dirPath, prefix, resultPath);
|
||||
if(number != 0)
|
||||
{
|
||||
_fileName = resultPath;
|
||||
_mustBeDeleted = true;
|
||||
}
|
||||
return number;
|
||||
}
|
||||
|
||||
bool CTempFile::Create(LPCTSTR prefix, CSysString &resultPath)
|
||||
{
|
||||
CSysString tempPath;
|
||||
if(!MyGetTempPath(tempPath))
|
||||
return false;
|
||||
if (Create(tempPath, prefix, resultPath) != 0)
|
||||
return true;
|
||||
if(!MyGetWindowsDirectory(tempPath))
|
||||
return false;
|
||||
return (Create(tempPath, prefix, resultPath) != 0);
|
||||
}
|
||||
|
||||
bool CTempFile::Remove()
|
||||
{
|
||||
if (!_mustBeDeleted)
|
||||
return true;
|
||||
_mustBeDeleted = !DeleteFileAlways(_fileName);
|
||||
return !_mustBeDeleted;
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
|
||||
UINT CTempFileW::Create(LPCWSTR dirPath, LPCWSTR prefix, UString &resultPath)
|
||||
{
|
||||
Remove();
|
||||
UINT number = MyGetTempFileName(dirPath, prefix, resultPath);
|
||||
if(number != 0)
|
||||
{
|
||||
_fileName = resultPath;
|
||||
_mustBeDeleted = true;
|
||||
}
|
||||
return number;
|
||||
}
|
||||
|
||||
bool CTempFileW::Create(LPCWSTR prefix, UString &resultPath)
|
||||
{
|
||||
UString tempPath;
|
||||
if(!MyGetTempPath(tempPath))
|
||||
return false;
|
||||
if (Create(tempPath, prefix, resultPath) != 0)
|
||||
return true;
|
||||
if(!MyGetWindowsDirectory(tempPath))
|
||||
return false;
|
||||
return (Create(tempPath, prefix, resultPath) != 0);
|
||||
}
|
||||
|
||||
bool CTempFileW::Remove()
|
||||
{
|
||||
if (!_mustBeDeleted)
|
||||
return true;
|
||||
_mustBeDeleted = !DeleteFileAlways(_fileName);
|
||||
return !_mustBeDeleted;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
bool CreateTempDirectory(LPCTSTR prefix, CSysString &dirName)
|
||||
{
|
||||
/*
|
||||
CSysString prefix = tempPath + prefixChars;
|
||||
CRandom random;
|
||||
random.Init();
|
||||
*/
|
||||
while(true)
|
||||
{
|
||||
CTempFile tempFile;
|
||||
if (!tempFile.Create(prefix, dirName))
|
||||
return false;
|
||||
if (!::DeleteFile(dirName))
|
||||
return false;
|
||||
/*
|
||||
UINT32 randomNumber = random.Generate();
|
||||
TCHAR randomNumberString[32];
|
||||
_stprintf(randomNumberString, _T("%04X"), randomNumber);
|
||||
dirName = prefix + randomNumberString;
|
||||
*/
|
||||
if(NFind::DoesFileExist(dirName))
|
||||
continue;
|
||||
if (MyCreateDirectory(dirName))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_ALREADY_EXISTS)
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
bool CTempDirectory::Create(LPCTSTR prefix)
|
||||
{
|
||||
Remove();
|
||||
return (_mustBeDeleted = CreateTempDirectory(prefix, _tempDir));
|
||||
}
|
||||
|
||||
#ifndef _UNICODE
|
||||
|
||||
bool CreateTempDirectory(LPCWSTR prefix, UString &dirName)
|
||||
{
|
||||
/*
|
||||
CSysString prefix = tempPath + prefixChars;
|
||||
CRandom random;
|
||||
random.Init();
|
||||
*/
|
||||
while(true)
|
||||
{
|
||||
CTempFileW tempFile;
|
||||
if (!tempFile.Create(prefix, dirName))
|
||||
return false;
|
||||
if (!DeleteFileAlways(dirName))
|
||||
return false;
|
||||
/*
|
||||
UINT32 randomNumber = random.Generate();
|
||||
TCHAR randomNumberString[32];
|
||||
_stprintf(randomNumberString, _T("%04X"), randomNumber);
|
||||
dirName = prefix + randomNumberString;
|
||||
*/
|
||||
if(NFind::DoesFileExist(dirName))
|
||||
continue;
|
||||
if (MyCreateDirectory(dirName))
|
||||
return true;
|
||||
if (::GetLastError() != ERROR_ALREADY_EXISTS)
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
bool CTempDirectoryW::Create(LPCWSTR prefix)
|
||||
{
|
||||
Remove();
|
||||
return (_mustBeDeleted = CreateTempDirectory(prefix, _tempDir));
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
}}}
|
||||
Reference in New Issue
Block a user