mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-06 09:44:39 +00:00
System: Fix getMagicNumber on windows.
getMagicNumber was treating the _binary_ data it read in as a null terminated string. This resulted in the std::string calculating the length, and causing an assert in other code that assumed that the length it passed was the same as the length of the string it would get back. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@112586 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a805b2ded8
commit
1211d43abf
@ -722,7 +722,7 @@ Path::eraseFromDisk(bool remove_contents, std::string *ErrStr) const {
|
||||
|
||||
bool Path::getMagicNumber(std::string& Magic, unsigned len) const {
|
||||
assert(len < 1024 && "Request for magic string too long");
|
||||
char* buf = (char*) alloca(1 + len);
|
||||
char* buf = reinterpret_cast<char*>(alloca(len));
|
||||
|
||||
HANDLE h = CreateFile(path.c_str(),
|
||||
GENERIC_READ,
|
||||
@ -741,8 +741,7 @@ bool Path::getMagicNumber(std::string& Magic, unsigned len) const {
|
||||
if (!ret || nRead != len)
|
||||
return false;
|
||||
|
||||
buf[len] = '\0';
|
||||
Magic = buf;
|
||||
Magic = std::string(buf, len);
|
||||
return true;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user