Skip to content

Commit

Permalink
Backed out changeset b6ebaaea0102 (bug 1741465) for causing bustages …
Browse files Browse the repository at this point in the history
…in IOUtils.cpp

CLOSED TREE
  • Loading branch information
Alexandru Michis committed Dec 1, 2021
1 parent 14114be commit f236a62
Show file tree
Hide file tree
Showing 3 changed files with 25 additions and 37 deletions.
2 changes: 1 addition & 1 deletion dom/chrome-webidl/IOUtils.webidl
Original file line number Diff line number Diff line change
Expand Up @@ -284,7 +284,7 @@ dictionary ReadOptions : ReadUTF8Options {
* The offset into the file to read from. If unspecified, the file will be read
* from the start.
*/
unsigned long long offset = 0;
unsigned long offset = 0;

/**
* The max bytes to read from the file at path. If unspecified, the entire
Expand Down
58 changes: 23 additions & 35 deletions dom/system/IOUtils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -829,7 +829,7 @@ already_AddRefed<Promise> IOUtils::CreateJSPromise(GlobalObject& aGlobal) {

/* static */
Result<IOUtils::JsBuffer, IOUtils::IOError> IOUtils::ReadSync(
nsIFile* aFile, const uint64_t aOffset, const Maybe<uint32_t> aMaxBytes,
nsIFile* aFile, const uint32_t aOffset, const Maybe<uint32_t> aMaxBytes,
const bool aDecompress, IOUtils::BufferKind aBufferKind) {
MOZ_ASSERT(!NS_IsMainThread());

Expand All @@ -840,62 +840,50 @@ Result<IOUtils::JsBuffer, IOUtils::IOError> IOUtils::ReadSync(
"The `maxBytes` and `decompress` options are not compatible"));
}

if (aOffset > static_cast<uint64_t>(INT64_MAX)) {
return Err(IOError(NS_ERROR_ILLEGAL_INPUT)
.WithMessage("Requested offset is too large (%" PRIu64
" > %" PRId64 ")",
aOffset, INT64_MAX));
}

const int64_t offset = static_cast<int64_t>(aOffset);

RefPtr<nsFileStream> stream = new nsFileStream();
if (nsresult rv =
stream->Init(aFile, PR_RDONLY | nsIFile::OS_READAHEAD, 0666, 0);
NS_FAILED(rv)) {
return Err(IOError(rv).WithMessage("Could not open the file at %s",
aFile->HumanReadablePath().get()));
}

size_t bufSize = 0;
int64_t bufSize = 0;

if (aMaxBytes.isNothing()) {
// Limitation: We cannot read more than the maximum size of a TypedArray
// (UINT32_MAX bytes). Reject if we have been requested to
// perform too large of a read.
// Limitation: We cannot read files that are larger than the max size of a
// TypedArray (UINT32_MAX bytes). Reject if the file is too
// big to be read.

int64_t rawStreamSize = -1;
if (nsresult rv = stream->GetSize(&rawStreamSize); NS_FAILED(rv)) {
int64_t streamSize = -1;
if (nsresult rv = stream->GetSize(&streamSize); NS_FAILED(rv)) {
return Err(IOError(NS_ERROR_FILE_ACCESS_DENIED)
.WithMessage("Could not get info for the file at %s",
aFile->HumanReadablePath().get()));
}
MOZ_RELEASE_ASSERT(rawStreamSize >= 0);
MOZ_RELEASE_ASSERT(streamSize >= 0);

uint64_t streamSize = static_cast<uint64_t>(rawStreamSize);
if (aOffset >= rawStreamSize) {
if (streamSize > static_cast<int64_t>(UINT32_MAX)) {
return Err(
IOError(NS_ERROR_FILE_TOO_BIG)
.WithMessage("Could not read the file at %s because it is too "
"large(size=%" PRId64 " bytes)",
aFile->HumanReadablePath().get(), streamSize));
}
bufSize = static_cast<uint32_t>(streamSize);

if (aOffset >= bufSize) {
bufSize = 0;
} else {
streamSize -= offset;
if (streamSize > static_cast<int64_t>(UINT32_MAX)) {
return Err(IOError(NS_ERROR_FILE_TOO_BIG)
.WithMessage(
"Could not read the file at %s with offset %" PRIu32
" because it is too large(size=%" PRId64 " bytes)",
aFile->HumanReadablePath().get(), offset,
streamSize));
}

bufSize = static_cast<size_t>(streamSize);
bufSize = bufSize - aOffset;
}
} else {
bufSize = static_cast<size_t>(aMaxBytes.value());
bufSize = aMaxBytes.value();
}

if (offset > 0) {
if (nsresult rv = stream->Seek(PR_SEEK_SET, offset); NS_FAILED(rv)) {
if (aOffset > 0) {
if (nsresult rv = stream->Seek(PR_SEEK_SET, aOffset); NS_FAILED(rv)) {
return Err(IOError(rv).WithMessage(
"Could not seek to position %" PRId64 " in file %s", offset,
"Could not seek to position %" PRId64 " in file %s", aOffset,
aFile->HumanReadablePath().get()));
}
}
Expand Down
2 changes: 1 addition & 1 deletion dom/system/IOUtils.h
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,7 @@ class IOUtils final {
* error.
*/
static Result<JsBuffer, IOError> ReadSync(nsIFile* aFile,
const uint64_t aOffset,
const uint32_t aOffset,
const Maybe<uint32_t> aMaxBytes,
const bool aDecompress,
BufferKind aBufferKind);
Expand Down

0 comments on commit f236a62

Please sign in to comment.