gh-138775: fix handle python -m base64 stdin correct with EOF signal (GH-138776)

* fix: handle  stdin correct with EOF single.
* fix: flollow the comments when pipe stdin use buffer
* Apply suggestions from code review
* fix: apply review comments in Lib/base64.py
* fix: address comments
* Reword comment and NEWS entry.

---------

Signed-off-by: yihong0618 <zouzou0208@gmail.com>
Co-authored-by: Bénédikt Tran <10796600+picnixz@users.noreply.github.com>
Co-authored-by: Peter Bierma <zintensitydev@gmail.com>
Co-authored-by: Gregory P. Smith <greg@krypto.org>
This commit is contained in:
yihong
2025-11-12 07:47:57 +08:00
committed by GitHub
parent 4359706ac8
commit f5c2a41f9a
2 changed files with 10 additions and 1 deletions

View File

@@ -604,7 +604,14 @@ def main():
with open(args[0], 'rb') as f:
func(f, sys.stdout.buffer)
else:
func(sys.stdin.buffer, sys.stdout.buffer)
if sys.stdin.isatty():
# gh-138775: read terminal input data all at once to detect EOF
import io
data = sys.stdin.buffer.read()
buffer = io.BytesIO(data)
else:
buffer = sys.stdin.buffer
func(buffer, sys.stdout.buffer)
if __name__ == '__main__':

View File

@@ -0,0 +1,2 @@
Use of ``python -m`` with :mod:`base64` has been fixed to detect input from a
terminal so that it properly notices EOF.