fix: -Wunsafe-buffer-usage warnings in asar file IO (#43624)
* fix: -Wunsafe-buffer-usage warnings in ScopedTemporaryFile::InitFromFile() * fix: -Wunsafe-buffer-usage warnings in Archive::Init()
This commit is contained in:
parent
5718ea4e1e
commit
f1019c2c4a
2 changed files with 15 additions and 25 deletions
|
@ -201,22 +201,19 @@ bool Archive::Init() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<char> buf;
|
std::vector<uint8_t> buf;
|
||||||
int len;
|
|
||||||
|
|
||||||
buf.resize(8);
|
buf.resize(8);
|
||||||
{
|
{
|
||||||
electron::ScopedAllowBlockingForElectron allow_blocking;
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
||||||
len = file_.ReadAtCurrentPos(buf.data(), buf.size());
|
if (!file_.ReadAtCurrentPosAndCheck(buf)) {
|
||||||
}
|
PLOG(ERROR) << "Failed to read header size from " << path_.value();
|
||||||
if (len != static_cast<int>(buf.size())) {
|
return false;
|
||||||
PLOG(ERROR) << "Failed to read header size from " << path_.value();
|
}
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t size;
|
uint32_t size;
|
||||||
if (!base::PickleIterator(base::Pickle::WithData(base::as_byte_span(buf)))
|
if (!base::PickleIterator(base::Pickle::WithData(buf)).ReadUInt32(&size)) {
|
||||||
.ReadUInt32(&size)) {
|
|
||||||
LOG(ERROR) << "Failed to parse header size from " << path_.value();
|
LOG(ERROR) << "Failed to parse header size from " << path_.value();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -224,16 +221,14 @@ bool Archive::Init() {
|
||||||
buf.resize(size);
|
buf.resize(size);
|
||||||
{
|
{
|
||||||
electron::ScopedAllowBlockingForElectron allow_blocking;
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
||||||
len = file_.ReadAtCurrentPos(buf.data(), buf.size());
|
if (!file_.ReadAtCurrentPosAndCheck(buf)) {
|
||||||
}
|
PLOG(ERROR) << "Failed to read header from " << path_.value();
|
||||||
if (len != static_cast<int>(buf.size())) {
|
return false;
|
||||||
PLOG(ERROR) << "Failed to read header from " << path_.value();
|
}
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string header;
|
std::string header;
|
||||||
if (!base::PickleIterator(base::Pickle::WithData(base::as_byte_span(buf)))
|
if (!base::PickleIterator(base::Pickle::WithData(buf)).ReadString(&header)) {
|
||||||
.ReadString(&header)) {
|
|
||||||
LOG(ERROR) << "Failed to parse header from " << path_.value();
|
LOG(ERROR) << "Failed to parse header from " << path_.value();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,20 +62,15 @@ bool ScopedTemporaryFile::InitFromFile(
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
electron::ScopedAllowBlockingForElectron allow_blocking;
|
electron::ScopedAllowBlockingForElectron allow_blocking;
|
||||||
std::vector<char> buf(size);
|
std::vector<uint8_t> buf(size);
|
||||||
int len = src->Read(offset, buf.data(), buf.size());
|
if (!src->ReadAndCheck(offset, buf))
|
||||||
if (len != static_cast<int>(size))
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (integrity)
|
if (integrity)
|
||||||
ValidateIntegrityOrDie(base::as_byte_span(buf), *integrity);
|
ValidateIntegrityOrDie(buf, *integrity);
|
||||||
|
|
||||||
base::File dest(path_, base::File::FLAG_OPEN | base::File::FLAG_WRITE);
|
base::File dest(path_, base::File::FLAG_OPEN | base::File::FLAG_WRITE);
|
||||||
if (!dest.IsValid())
|
return dest.IsValid() && dest.WriteAtCurrentPosAndCheck(buf);
|
||||||
return false;
|
|
||||||
|
|
||||||
return dest.WriteAtCurrentPos(buf.data(), buf.size()) ==
|
|
||||||
static_cast<int>(size);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace asar
|
} // namespace asar
|
||||||
|
|
Loading…
Reference in a new issue