Commit 5bc2cf61 authored by Shawn Bohrer's avatar Shawn Bohrer

monkey: exec scripts in global scope

Commit 59581a8a "Add python 3.5
selectors test, and remove the devpoll selector under 3.5. also update
the monkey documentation." Introduced a regression by moving the exec of
scripts into a main() function. If the script being run with exec has
import statements those are now locally scoped to the main() function
which can break the script.

It does not appear that this local scoping was intentional so the fix is
to exec the script in the global scope, returning the previous behavior.
This also requires setting __package__ = None otherwise the script
appears to be run in the gevent __package__
parent f3acb176
...@@ -672,8 +672,10 @@ def main(): ...@@ -672,8 +672,10 @@ def main():
__package__ = None __package__ = None
assert __package__ is None assert __package__ is None
globals()['__file__'] = sys.argv[0] # issue #302 globals()['__file__'] = sys.argv[0] # issue #302
# Clear package so exec'd script doesn't appear in gevent package
globals()['__package__'] = None
with open(sys.argv[0]) as f: with open(sys.argv[0]) as f:
exec(f.read()) exec(f.read(), globals())
else: else:
print(script_help) print(script_help)
......
import sys
if 'gevent' not in sys.modules:
from subprocess import Popen
args = [sys.executable, '-m', 'gevent.monkey', __file__]
p = Popen(args)
code = p.wait()
assert code == 0, code
else:
from textwrap import dedent
def use_import():
dedent(" text")
use_import()
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment