mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-10 08:09:26 +01:00
CommonFuncs: LastStrerrorString added
This commit is contained in:
parent
4e40fad248
commit
4e5fe6366a
@ -22,27 +22,35 @@
|
|||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
#define strerror_r(err, buf, len) strerror_s(buf, len, err)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Generic function to get last error message.
|
constexpr size_t BUFFER_SIZE = 256;
|
||||||
// Call directly after the command or use the error num.
|
|
||||||
// This function might change the error code.
|
// Wrapper function to get last strerror(errno) string.
|
||||||
std::string GetLastErrorMsg()
|
// This function might change the error code.
|
||||||
{
|
std::string LastStrerrorString()
|
||||||
const size_t buff_size = 256;
|
{
|
||||||
char err_str[buff_size];
|
char error_message[BUFFER_SIZE];
|
||||||
|
|
||||||
#ifdef _WIN32
|
|
||||||
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, nullptr, GetLastError(),
|
|
||||||
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), err_str, buff_size, nullptr);
|
|
||||||
#else
|
|
||||||
// We assume that the XSI-compliant version of strerror_r (returns int) is used
|
// We assume that the XSI-compliant version of strerror_r (returns int) is used
|
||||||
// rather than the GNU version (returns char*). The returned value is stored to
|
// rather than the GNU version (returns char*). The returned value is stored to
|
||||||
// an int variable to get a compile-time check that the return type is not char*.
|
// an int variable to get a compile-time check that the return type is not char*.
|
||||||
const int result = strerror_r(errno, err_str, buff_size);
|
const int result = strerror_r(errno, error_message, BUFFER_SIZE);
|
||||||
if (result != 0)
|
if (result != 0)
|
||||||
return "";
|
return "";
|
||||||
#endif
|
return std::string(error_message);
|
||||||
|
|
||||||
return std::string(err_str);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
// Wrapper function to get GetLastError() string.
|
||||||
|
// This function might change the error code.
|
||||||
|
std::string GetLastErrorString()
|
||||||
|
{
|
||||||
|
char error_message[BUFFER_SIZE];
|
||||||
|
|
||||||
|
FormatMessageA(FORMAT_MESSAGE_FROM_SYSTEM, nullptr, GetLastError(),
|
||||||
|
MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT), error_message, BUFFER_SIZE, nullptr);
|
||||||
|
return std::string(error_message);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@ -86,7 +86,12 @@ __declspec(dllimport) void __stdcall DebugBreak(void);
|
|||||||
}
|
}
|
||||||
#endif // WIN32 ndef
|
#endif // WIN32 ndef
|
||||||
|
|
||||||
// Generic function to get last error message.
|
// Wrapper function to get last strerror(errno) string.
|
||||||
// Call directly after the command or use the error num.
|
|
||||||
// This function might change the error code.
|
// This function might change the error code.
|
||||||
std::string GetLastErrorMsg();
|
std::string LastStrerrorString();
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
// Wrapper function to get GetLastError() string.
|
||||||
|
// This function might change the error code.
|
||||||
|
std::string GetLastErrorString();
|
||||||
|
#endif
|
||||||
|
@ -141,14 +141,14 @@ bool Delete(const std::string& filename)
|
|||||||
if (!DeleteFile(UTF8ToTStr(filename).c_str()))
|
if (!DeleteFile(UTF8ToTStr(filename).c_str()))
|
||||||
{
|
{
|
||||||
WARN_LOG(COMMON, "Delete: DeleteFile failed on %s: %s", filename.c_str(),
|
WARN_LOG(COMMON, "Delete: DeleteFile failed on %s: %s", filename.c_str(),
|
||||||
GetLastErrorMsg().c_str());
|
GetLastErrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if (unlink(filename.c_str()) == -1)
|
if (unlink(filename.c_str()) == -1)
|
||||||
{
|
{
|
||||||
WARN_LOG(COMMON, "Delete: unlink failed on %s: %s", filename.c_str(),
|
WARN_LOG(COMMON, "Delete: unlink failed on %s: %s", filename.c_str(),
|
||||||
GetLastErrorMsg().c_str());
|
LastStrerrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
@ -241,11 +241,14 @@ bool DeleteDir(const std::string& filename)
|
|||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
if (::RemoveDirectory(UTF8ToTStr(filename).c_str()))
|
if (::RemoveDirectory(UTF8ToTStr(filename).c_str()))
|
||||||
return true;
|
return true;
|
||||||
|
ERROR_LOG(COMMON, "DeleteDir: RemoveDirectory failed on %s: %s", filename.c_str(),
|
||||||
|
GetLastErrorString().c_str());
|
||||||
#else
|
#else
|
||||||
if (rmdir(filename.c_str()) == 0)
|
if (rmdir(filename.c_str()) == 0)
|
||||||
return true;
|
return true;
|
||||||
|
ERROR_LOG(COMMON, "DeleteDir: rmdir failed on %s: %s", filename.c_str(),
|
||||||
|
LastStrerrorString().c_str());
|
||||||
#endif
|
#endif
|
||||||
ERROR_LOG(COMMON, "DeleteDir: %s: %s", filename.c_str(), GetLastErrorMsg().c_str());
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -268,12 +271,14 @@ bool Rename(const std::string& srcFilename, const std::string& destFilename)
|
|||||||
if (MoveFile(sf.c_str(), df.c_str()))
|
if (MoveFile(sf.c_str(), df.c_str()))
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
ERROR_LOG(COMMON, "Rename: MoveFile failed on %s --> %s: %s", srcFilename.c_str(),
|
||||||
|
destFilename.c_str(), GetLastErrorString().c_str());
|
||||||
#else
|
#else
|
||||||
if (rename(srcFilename.c_str(), destFilename.c_str()) == 0)
|
if (rename(srcFilename.c_str(), destFilename.c_str()) == 0)
|
||||||
return true;
|
return true;
|
||||||
|
ERROR_LOG(COMMON, "Rename: rename failed on %s --> %s: %s", srcFilename.c_str(),
|
||||||
|
destFilename.c_str(), LastStrerrorString().c_str());
|
||||||
#endif
|
#endif
|
||||||
ERROR_LOG(COMMON, "Rename: failed %s --> %s: %s", srcFilename.c_str(), destFilename.c_str(),
|
|
||||||
GetLastErrorMsg().c_str());
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -321,7 +326,7 @@ bool Copy(const std::string& srcFilename, const std::string& destFilename)
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
ERROR_LOG(COMMON, "Copy: failed %s --> %s: %s", srcFilename.c_str(), destFilename.c_str(),
|
ERROR_LOG(COMMON, "Copy: failed %s --> %s: %s", srcFilename.c_str(), destFilename.c_str(),
|
||||||
GetLastErrorMsg().c_str());
|
GetLastErrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
#else
|
#else
|
||||||
|
|
||||||
@ -335,8 +340,7 @@ bool Copy(const std::string& srcFilename, const std::string& destFilename)
|
|||||||
OpenFStream(input, srcFilename, std::ifstream::in | std::ifstream::binary);
|
OpenFStream(input, srcFilename, std::ifstream::in | std::ifstream::binary);
|
||||||
if (!input.is_open())
|
if (!input.is_open())
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "Copy: input failed %s --> %s: %s", srcFilename.c_str(), destFilename.c_str(),
|
ERROR_LOG(COMMON, "Copy: failed to open %s", srcFilename.c_str());
|
||||||
GetLastErrorMsg().c_str());
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -346,7 +350,7 @@ bool Copy(const std::string& srcFilename, const std::string& destFilename)
|
|||||||
if (!output.IsOpen())
|
if (!output.IsOpen())
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "Copy: output failed %s --> %s: %s", srcFilename.c_str(),
|
ERROR_LOG(COMMON, "Copy: output failed %s --> %s: %s", srcFilename.c_str(),
|
||||||
destFilename.c_str(), GetLastErrorMsg().c_str());
|
destFilename.c_str(), LastStrerrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -357,8 +361,8 @@ bool Copy(const std::string& srcFilename, const std::string& destFilename)
|
|||||||
input.read(buffer, BSIZE);
|
input.read(buffer, BSIZE);
|
||||||
if (!input)
|
if (!input)
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "Copy: failed reading from source, %s --> %s: %s", srcFilename.c_str(),
|
ERROR_LOG(COMMON, "Copy: failed reading from source, %s --> %s", srcFilename.c_str(),
|
||||||
destFilename.c_str(), GetLastErrorMsg().c_str());
|
destFilename.c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -366,7 +370,7 @@ bool Copy(const std::string& srcFilename, const std::string& destFilename)
|
|||||||
if (!output.WriteBytes(buffer, BSIZE))
|
if (!output.WriteBytes(buffer, BSIZE))
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "Copy: failed writing to output, %s --> %s: %s", srcFilename.c_str(),
|
ERROR_LOG(COMMON, "Copy: failed writing to output, %s --> %s: %s", srcFilename.c_str(),
|
||||||
destFilename.c_str(), GetLastErrorMsg().c_str());
|
destFilename.c_str(), LastStrerrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -394,14 +398,14 @@ u64 GetSize(FILE* f)
|
|||||||
u64 pos = ftello(f);
|
u64 pos = ftello(f);
|
||||||
if (fseeko(f, 0, SEEK_END) != 0)
|
if (fseeko(f, 0, SEEK_END) != 0)
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "GetSize: seek failed %p: %s", f, GetLastErrorMsg().c_str());
|
ERROR_LOG(COMMON, "GetSize: seek failed %p: %s", f, LastStrerrorString().c_str());
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
u64 size = ftello(f);
|
u64 size = ftello(f);
|
||||||
if ((size != pos) && (fseeko(f, pos, SEEK_SET) != 0))
|
if ((size != pos) && (fseeko(f, pos, SEEK_SET) != 0))
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "GetSize: seek failed %p: %s", f, GetLastErrorMsg().c_str());
|
ERROR_LOG(COMMON, "GetSize: seek failed %p: %s", f, LastStrerrorString().c_str());
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -416,7 +420,7 @@ bool CreateEmptyFile(const std::string& filename)
|
|||||||
if (!File::IOFile(filename, "wb"))
|
if (!File::IOFile(filename, "wb"))
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "CreateEmptyFile: failed %s: %s", filename.c_str(),
|
ERROR_LOG(COMMON, "CreateEmptyFile: failed %s: %s", filename.c_str(),
|
||||||
GetLastErrorMsg().c_str());
|
LastStrerrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -620,7 +624,7 @@ std::string GetCurrentDir()
|
|||||||
char* dir = __getcwd(nullptr, 0);
|
char* dir = __getcwd(nullptr, 0);
|
||||||
if (!dir)
|
if (!dir)
|
||||||
{
|
{
|
||||||
ERROR_LOG(COMMON, "GetCurrentDirectory failed: %s", GetLastErrorMsg().c_str());
|
ERROR_LOG(COMMON, "GetCurrentDirectory failed: %s", LastStrerrorString().c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
std::string strDir = dir;
|
std::string strDir = dir;
|
||||||
|
@ -136,7 +136,7 @@ u8* MemArena::FindMemoryBase()
|
|||||||
u8* base = static_cast<u8*>(VirtualAlloc(nullptr, memory_size, MEM_RESERVE, PAGE_READWRITE));
|
u8* base = static_cast<u8*>(VirtualAlloc(nullptr, memory_size, MEM_RESERVE, PAGE_READWRITE));
|
||||||
if (!base)
|
if (!base)
|
||||||
{
|
{
|
||||||
PanicAlert("Failed to map enough memory space: %s", GetLastErrorMsg().c_str());
|
PanicAlert("Failed to map enough memory space: %s", GetLastErrorString().c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
VirtualFree(base, 0, MEM_RELEASE);
|
VirtualFree(base, 0, MEM_RELEASE);
|
||||||
@ -153,7 +153,7 @@ u8* MemArena::FindMemoryBase()
|
|||||||
void* base = mmap(nullptr, memory_size, PROT_NONE, flags, -1, 0);
|
void* base = mmap(nullptr, memory_size, PROT_NONE, flags, -1, 0);
|
||||||
if (base == MAP_FAILED)
|
if (base == MAP_FAILED)
|
||||||
{
|
{
|
||||||
PanicAlert("Failed to map enough memory space: %s", GetLastErrorMsg().c_str());
|
PanicAlert("Failed to map enough memory space: %s", LastStrerrorString().c_str());
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
munmap(base, memory_size);
|
munmap(base, memory_size);
|
||||||
|
@ -88,20 +88,13 @@ void FreeMemoryPages(void* ptr, size_t size)
|
|||||||
{
|
{
|
||||||
if (ptr)
|
if (ptr)
|
||||||
{
|
{
|
||||||
bool error_occurred = false;
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
if (!VirtualFree(ptr, 0, MEM_RELEASE))
|
if (!VirtualFree(ptr, 0, MEM_RELEASE))
|
||||||
error_occurred = true;
|
PanicAlert("FreeMemoryPages failed!\nVirtualFree: %s", GetLastErrorString().c_str());
|
||||||
#else
|
#else
|
||||||
int retval = munmap(ptr, size);
|
if (munmap(ptr, size) != 0)
|
||||||
|
PanicAlert("FreeMemoryPages failed!\nmunmap: %s", LastStrerrorString().c_str());
|
||||||
if (retval != 0)
|
|
||||||
error_occurred = true;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (error_occurred)
|
|
||||||
PanicAlert("FreeMemoryPages failed!\n%s", GetLastErrorMsg().c_str());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,60 +112,41 @@ void FreeAlignedMemory(void* ptr)
|
|||||||
|
|
||||||
void ReadProtectMemory(void* ptr, size_t size)
|
void ReadProtectMemory(void* ptr, size_t size)
|
||||||
{
|
{
|
||||||
bool error_occurred = false;
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
DWORD oldValue;
|
DWORD oldValue;
|
||||||
if (!VirtualProtect(ptr, size, PAGE_NOACCESS, &oldValue))
|
if (!VirtualProtect(ptr, size, PAGE_NOACCESS, &oldValue))
|
||||||
error_occurred = true;
|
PanicAlert("ReadProtectMemory failed!\nVirtualProtect: %s", GetLastErrorString().c_str());
|
||||||
#else
|
#else
|
||||||
int retval = mprotect(ptr, size, PROT_NONE);
|
if (mprotect(ptr, size, PROT_NONE) != 0)
|
||||||
|
PanicAlert("ReadProtectMemory failed!\nmprotect: %s", LastStrerrorString().c_str());
|
||||||
if (retval != 0)
|
|
||||||
error_occurred = true;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (error_occurred)
|
|
||||||
PanicAlert("ReadProtectMemory failed!\n%s", GetLastErrorMsg().c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void WriteProtectMemory(void* ptr, size_t size, bool allowExecute)
|
void WriteProtectMemory(void* ptr, size_t size, bool allowExecute)
|
||||||
{
|
{
|
||||||
bool error_occurred = false;
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
DWORD oldValue;
|
DWORD oldValue;
|
||||||
if (!VirtualProtect(ptr, size, allowExecute ? PAGE_EXECUTE_READ : PAGE_READONLY, &oldValue))
|
if (!VirtualProtect(ptr, size, allowExecute ? PAGE_EXECUTE_READ : PAGE_READONLY, &oldValue))
|
||||||
error_occurred = true;
|
PanicAlert("WriteProtectMemory failed!\nVirtualProtect: %s", GetLastErrorString().c_str());
|
||||||
#else
|
#else
|
||||||
int retval = mprotect(ptr, size, allowExecute ? (PROT_READ | PROT_EXEC) : PROT_READ);
|
if (mprotect(ptr, size, allowExecute ? (PROT_READ | PROT_EXEC) : PROT_READ) != 0)
|
||||||
|
PanicAlert("WriteProtectMemory failed!\nmprotect: %s", LastStrerrorString().c_str());
|
||||||
if (retval != 0)
|
|
||||||
error_occurred = true;
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (error_occurred)
|
|
||||||
PanicAlert("WriteProtectMemory failed!\n%s", GetLastErrorMsg().c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void UnWriteProtectMemory(void* ptr, size_t size, bool allowExecute)
|
void UnWriteProtectMemory(void* ptr, size_t size, bool allowExecute)
|
||||||
{
|
{
|
||||||
bool error_occurred = false;
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
DWORD oldValue;
|
DWORD oldValue;
|
||||||
if (!VirtualProtect(ptr, size, allowExecute ? PAGE_EXECUTE_READWRITE : PAGE_READWRITE, &oldValue))
|
if (!VirtualProtect(ptr, size, allowExecute ? PAGE_EXECUTE_READWRITE : PAGE_READWRITE, &oldValue))
|
||||||
error_occurred = true;
|
PanicAlert("UnWriteProtectMemory failed!\nVirtualProtect: %s", GetLastErrorString().c_str());
|
||||||
#else
|
#else
|
||||||
int retval = mprotect(ptr, size, allowExecute ? (PROT_READ | PROT_WRITE | PROT_EXEC) :
|
if (mprotect(ptr, size,
|
||||||
PROT_WRITE | PROT_READ);
|
allowExecute ? (PROT_READ | PROT_WRITE | PROT_EXEC) : PROT_WRITE | PROT_READ) != 0)
|
||||||
|
{
|
||||||
if (retval != 0)
|
PanicAlert("UnWriteProtectMemory failed!\nmprotect: %s", LastStrerrorString().c_str());
|
||||||
error_occurred = true;
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (error_occurred)
|
|
||||||
PanicAlert("UnWriteProtectMemory failed!\n%s", GetLastErrorMsg().c_str());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t MemPhysical()
|
size_t MemPhysical()
|
||||||
|
@ -291,7 +291,7 @@ bool SDCardCreate(u64 disk_size /*in MB*/, const std::string& filename)
|
|||||||
FailWrite:
|
FailWrite:
|
||||||
ERROR_LOG(COMMON, "Could not write to '%s', aborting...", filename.c_str());
|
ERROR_LOG(COMMON, "Could not write to '%s', aborting...", filename.c_str());
|
||||||
if (unlink(filename.c_str()) < 0)
|
if (unlink(filename.c_str()) < 0)
|
||||||
ERROR_LOG(COMMON, "unlink(%s) failed: %s", filename.c_str(), GetLastErrorMsg().c_str());
|
ERROR_LOG(COMMON, "unlink(%s) failed: %s", filename.c_str(), LastStrerrorString().c_str());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user