gh-129005: Avoid copy in _pyio.FileIO.readinto #129006
Closed
+15
−4
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
os.read
allocated and filled a buffer by callingread(2)
, than that data was copied into the user provied buffer. Read directly into the caller's buffer instead by usingos.readv
.self.read()
was doing the closed and readable checks so move those intoreadinto
PR of
readinto
first as it is a lot smaller diff than thereadall
code but has the coreos.read
->os.readv
change. Inmain
how the buffer is expanded between_io
(new_buffersize
) and_pyio
(inline inread()
) should get lined up.