Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support redirection of stdout / stderr into CPython descriptors #31

Open
GoogleCodeExporter opened this issue Aug 5, 2015 · 1 comment

Comments

@GoogleCodeExporter
Copy link

What steps will reproduce the problem?
1. Wrap some code that contains WRITE statements with f2py
2. Try to capture this output on Python stdout / stderr descriptors
3. Watch yourself fail

What is the expected output? What do you see instead?

I would expect to be able to capture the text printed by wrapped routines from 
inside Python.

What version of the product are you using? On what operating system?

Latest NumPy / SciPy / f2py / Python 2.7 / Linux + Windows

Please provide any additional information below.

See e.g. http://projects.scipy.org/scipy/ticket/1350 for discussion:

In essence, SciPy wraps a lot around Fortran code, e.g. for optimizers. 
Unfortunately, these codes print a lot of interesting debugging (not only 
debugging, actually) information on stdout / stderr and this output can not be 
captured / parsed automatically from within Python.

It is possible to modify the wrappers to return more information, but it is 
tedious and not practical to change every function that uses WRITE so that it 
adds text to a global string that will be returned to Python.

The solution that I have in mind is to implement an extra function from within 
f2py, e.g. WRITE_PYTHON which would be identical to WRITE, but actually use 
PySys_WriteStdout to write to the same descriptors that Python has opened.

Probably this will also require the modification of the Fortran codes, but mass 
replacement of WRITE with WRITE_PYTHON already looks much more reasonable.

Discussion and alternative solutions are welcome!

Thanks!

Original issue reported on code.google.com by yury.v.zaytsev on 3 Jan 2011 at 3:04

@GoogleCodeExporter
Copy link
Author

The references issue has moved: https://github.com/scipy/scipy/issues/1875

Original comment by yury.v.zaytsev on 26 Apr 2013 at 6:42

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant