Thread safe stdio proxy
Project description
stdio_proxy
stdio_proxy is a thread-safe library for Python 2.7 and Python 3.5+ that can temporarily redirect stdio to another objects.
Background
Python 3.5+ has redirect_stdout
and redirect_stderr
in contextlib
, that are utility functions for temporarily redirecting sys.stdout
and sys.stderr
to another file-like objects, respectively.
But those functions have the global side effect on sys.stdout
and sys.stderr
.
That means we cannot use those functions in most threaded applications.
- Python code
import contextlib
import io
import time
from concurrent.futures import ThreadPoolExecutor
def run(value):
for i in range(2):
print("Hello from {}:{}".format(value, i))
time.sleep(1)
def run_hook(value):
buf = io.StringIO()
with contextlib.redirect_stdout(buf):
run(value)
return buf.getvalue()
with ThreadPoolExecutor() as executor:
f1 = executor.submit(run, "th1")
f2 = executor.submit(run_hook, "th2")
f1.result()
result = f2.result()
print("===Done===")
print("Redirected Stdout:\n{}".format(result))
- What we want
Hello from th1:0
===Done===
Redirected Stdout:
Hello from th2:0
Hello from th1:1
Hello from th2:1
- Example of actual output
Hello from th1:0
===Done===
Redirected Stdout:
Hello from th2:0
Hello from th1:1
Hello from th2:1
This library aims to redirect those stdio correctly in threaded applications as well.
By just replacing run_hook
function with the following code, the result would be exactly the same as "what we want" :)
def run_hook(value):
buf = io.BytesIO()
with stdio_proxy.redirect_stdout(buf):
run(value)
return buf.getvalue()
Install
$ pip install stdio-proxy
Usage
- Redirect a buffer to
stdin
buf = io.BytesIO(b"foo\n")
with stdio_proxy.redirect_stdin(buf):
print("Read: {}".format(sys.stdin.readline()))
- Redirect
stdout
to a buffer
buf = io.BytesIO()
with stdio_proxy.redirect_stdout(buf):
print("foo")
print("Redirected: {}".format(buf.getvalue()))
- Redirect
stderr
to a buffer
buf = io.BytesIO()
with stdio_proxy.redirect_stderr(buf):
sys.stderr.write("foo\n")
print("Redirected: {}".format(buf.getvalue()))
License
MIT License
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distributions
File details
Details for the file stdio_proxy-0.1.1-py3-none-any.whl
.
File metadata
- Download URL: stdio_proxy-0.1.1-py3-none-any.whl
- Upload date:
- Size: 5.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.1 requests-toolbelt/0.9.1 tqdm/4.40.1 CPython/3.6.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9851ea970cb50cdc4a292ec6e2807117cc96d59309e28651729af7c5668e3696 |
|
MD5 | 5268551f7d6e1b1da0b73534709a5f84 |
|
BLAKE2b-256 | ebdebe99c68efc939324eccbc6aa45478b7d70d4445bae29e124693dff0d80c5 |
File details
Details for the file stdio_proxy-0.1.1-py2-none-any.whl
.
File metadata
- Download URL: stdio_proxy-0.1.1-py2-none-any.whl
- Upload date:
- Size: 5.8 kB
- Tags: Python 2
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.1 requests-toolbelt/0.9.1 tqdm/4.40.1 CPython/3.6.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2c7f9cd380131ba7802ff95484649c15752c8b3289a3fa8966bdfce7bec36ad4 |
|
MD5 | 24bc7b958c62cb668a715f3eee9f9623 |
|
BLAKE2b-256 | 60e51ce267adfc325531e6f9b3396d42eff8329cbd910557207e39b67a27e0ef |