[utils] sanitize_open: Allow any IO stream as stdout
Fixes: https://github.com/yt-dlp/yt-dlp/issues/3298#issuecomment-1181754989
This commit is contained in:
parent
a6bcaf71fc
commit
daef791100
1 changed files with 3 additions and 1 deletions
|
@ -598,7 +598,9 @@ def sanitize_open(filename, open_mode):
|
|||
if filename == '-':
|
||||
if sys.platform == 'win32':
|
||||
import msvcrt
|
||||
msvcrt.setmode(sys.stdout.fileno(), os.O_BINARY)
|
||||
# stdout may be any IO stream. Eg, when using contextlib.redirect_stdout
|
||||
with contextlib.suppress(io.UnsupportedOperation):
|
||||
msvcrt.setmode(sys.stdout.fileno(), os.O_BINARY)
|
||||
return (sys.stdout.buffer if hasattr(sys.stdout, 'buffer') else sys.stdout, filename)
|
||||
|
||||
for attempt in range(2):
|
||||
|
|
Loading…
Reference in a new issue