[Python-Dev] Disabling changing sys.argv[0] with runpy.run_module(...alter_sys=True)
Mike Kaplinskiy
mike.kaplinskiy at gmail.com
Tue Feb 16 23:56:20 EST 2016
Hey folks,
I hope this is the right list for this sort of thing (python-ideas seemed
more far-fetched).
For some context: there is currently a issue with pex that causes
sys.modules lookups to stop working for __main__. In turns this makes
unittest.run() & pkg_resources.resource_* fail. The root cause is that pex
uses runpy.run_module with alter_sys=False. The fix should be to just pass
alter_sys=True, but that changes sys.argv[0] and various existing pex files
depend on that being the pex file. You can read more at
https://github.com/pantsbuild/pex/pull/211 .
Conservatively, I'd like to propose adding an argument to disable this
behavior. The current behavior breaks a somewhat reasonable invariant that
you can restart your program via `os.execv([sys.executable] + sys.argv)`.
Moreover it might be user-friendly to add a `argv=sys.argv[1:]` argument to
set & restore the full arguments to the module, where `argv=None` disables
argv[0] switching.
What do you think?
Mike.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.python.org/pipermail/python-dev/attachments/20160216/6c5170e7/attachment.html>
More information about the Python-Dev
mailing list