fix wp8 directory control bug

This commit is contained in:
huanghsiwu 2014-09-19 15:54:18 +08:00
parent afd1271078
commit d42cec0708
1 changed files with 83 additions and 30 deletions

View File

@ -1068,10 +1068,13 @@ bool FileUtils::createDirectory(const std::string& path)
for(int i = 0 ; i < dirs.size() ; ++i) for(int i = 0 ; i < dirs.size() ; ++i)
{ {
subpath += dirs[i]; subpath += dirs[i];
BOOL ret = CreateDirectoryA(subpath.c_str(), NULL); if (i > 0 && !isDirectoryExist(subpath))
if (!ret && ERROR_ALREADY_EXISTS != GetLastError())
{ {
return false; BOOL ret = CreateDirectoryA(subpath.c_str(), NULL);
if (!ret && ERROR_ALREADY_EXISTS != GetLastError())
{
return false;
}
} }
} }
} }
@ -1081,14 +1084,17 @@ bool FileUtils::createDirectory(const std::string& path)
if ((GetFileAttributesA(path.c_str())) == INVALID_FILE_ATTRIBUTES) if ((GetFileAttributesA(path.c_str())) == INVALID_FILE_ATTRIBUTES)
{ {
subpath = ""; subpath = "";
for(int i = 0 ; i < dirs.size() ; ++i) for (int i = 0; i < dirs.size(); ++i)
{ {
subpath += dirs[i]; subpath += dirs[i];
BOOL ret = CreateDirectoryA(subpath.c_str(), NULL); if (!isDirectoryExist(subpath))
if (!ret && ERROR_ALREADY_EXISTS != GetLastError()) {
{ BOOL ret = CreateDirectoryA(subpath.c_str(), NULL);
return false; if (!ret && ERROR_ALREADY_EXISTS != GetLastError())
} {
return false;
}
}
} }
} }
return true; return true;
@ -1114,20 +1120,48 @@ bool FileUtils::removeDirectory(const std::string& path)
return false; return false;
#endif #endif
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WP8) || (CC_TARGET_PLATFORM == CC_PLATFORM_WINRT) #if (CC_TARGET_PLATFORM == CC_PLATFORM_WP8) || (CC_TARGET_PLATFORM == CC_PLATFORM_WINRT)
if (RemoveDirectoryA(path.c_str())) std::string Files = path + "*.*";
WIN32_FIND_DATA wfd;
HANDLE hFind = FindFirstFileEx(Files.c_str(), FindExInfoStandard, &wfd, FindExSearchNameMatch, NULL, 0);
bool Ret=true;
std::string Tmp;
if (hFind!=INVALID_HANDLE_VALUE)
{ {
return true; bool bFind=true;
while (bFind)
{
//. ..
if(wfd.cFileName[0]!='.')
{
Tmp = path + wfd.cFileName;
if (wfd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)
{
Tmp += '/';
Ret = Ret && this->removeDirectory(Tmp);
}
else
{
SetFileAttributes(Tmp.c_str(), FILE_ATTRIBUTE_NORMAL);
Ret = Ret && DeleteFile(Tmp.c_str());
}
}
bFind = FindNextFile(hFind, &wfd);
}
FindClose(hFind);
} }
if (Ret)
return RemoveDirectoryA(path.c_str());
return false; return false;
#endif #endif
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WIN32) #if (CC_TARGET_PLATFORM == CC_PLATFORM_WIN32)
std::string command = "rd /s /q "; std::string command = "cmd /c rd /s /q ";
// Path may include space. // Path may include space.
command += "\"" + path + "\""; command += "\"" + path + "\"";
if (WinExec(command.c_str(), SW_HIDE) > 31) if (WinExec(command.c_str(), SW_HIDE) > 31)
return true; return true;
else else
return false; return false;
#endif #endif
} }
@ -1151,13 +1185,22 @@ bool FileUtils::removeFile(const std::string &path)
return false; return false;
#endif #endif
#if (CC_TARGET_PLATFORM == CC_PLATFORM_WIN32) #if (CC_TARGET_PLATFORM == CC_PLATFORM_WIN32)
std::string command = "del /q "; std::string command = "cmd /c del /q ";
// Path may include space. std::string win32path = path;
command += "\"" + path + "\""; int len = win32path.length();
for (int i = 0; i < len; ++i)
{
if (win32path[i] == '/')
{
win32path[i] = '\\';
}
}
command += win32path;
if (WinExec(command.c_str(), SW_HIDE) > 31) if (WinExec(command.c_str(), SW_HIDE) > 31)
return true; return true;
else else
return false; return false;
#endif #endif
} }
@ -1176,13 +1219,23 @@ bool FileUtils::renameFile(const std::string &path, const std::string &oldname,
} }
return true; return true;
#else #else
std::string command = "ren "; std::string command = "cmd /c ren ";
// Path may include space. std::string win32path = path;
command += "\"" + path + oldname + "\" \"" + name + "\""; int len = win32path.length();
for (int i = 0; i < len; ++i)
{
if (win32path[i] == '/')
{
win32path[i] = '\\';
}
}
// Path may include space.
command += win32path + oldname + " " + name;
if (WinExec(command.c_str(), SW_HIDE) > 31) if (WinExec(command.c_str(), SW_HIDE) > 31)
return true; return true;
else else
return false; return false;
#endif #endif
} }