From 47ba97d9b669a9b7e058c78877493b7c09dc0a41 Mon Sep 17 00:00:00 2001 From: nggit Date: Mon, 11 Nov 2024 10:10:14 +0700 Subject: [PATCH] release 0.0.54 (#49) * fix when __globals__.py doesn't exist --------- Co-authored-by: nggit <12218311+nggit@users.noreply.github.com> --- httpout/__init__.py | 2 +- httpout/httpout.py | 14 ++++++-------- 2 files changed, 7 insertions(+), 9 deletions(-) diff --git a/httpout/__init__.py b/httpout/__init__.py index c5bbce9..e0eb7f2 100644 --- a/httpout/__init__.py +++ b/httpout/__init__.py @@ -1,6 +1,6 @@ # Copyright (c) 2024 nggit -__version__ = '0.0.53' +__version__ = '0.0.54' __all__ = ('HTTPOut',) from .httpout import HTTPOut # noqa: E402 diff --git a/httpout/httpout.py b/httpout/httpout.py index 84ef0a6..8ab8d7a 100644 --- a/httpout/httpout.py +++ b/httpout/httpout.py @@ -44,8 +44,10 @@ async def _on_worker_start(self, **worker): sys.path.insert(0, document_root) # provides __globals__, a worker-level context - worker['__globals__'] = new_module('__globals__') + module = new_module('__globals__') + worker['__globals__'] = module or ModuleType('__globals__') worker['modules'] = {'__globals__': worker['__globals__']} + py_import = builtins.__import__ def wait(coro, timeout=None): return asyncio.run_coroutine_threadsafe(coro, loop).result(timeout) @@ -77,8 +79,6 @@ def load_module(name, globals, level=0): return module - py_import = builtins.__import__ - def ho_import(name, globals=None, locals=None, fromlist=(), level=0): if (name not in sys.builtin_module_names and globals is not None and '__file__' in globals and @@ -147,17 +147,15 @@ def ho_import(name, globals=None, locals=None, fromlist=(), level=0): return py_import(name, globals, locals, fromlist, level) builtins.__import__ = ho_import + builtins.__globals__ = worker['__globals__'] g.wait = wait g.caches = {} g.executor = MultiThreadExecutor(thread_pool_size) g.executor.start() - if worker['__globals__']: - builtins.__globals__ = worker['__globals__'] - exec_module(worker['__globals__']) - else: - builtins.__globals__ = ModuleType('__globals__') + if module: + exec_module(module) async def _on_worker_stop(self, **worker): g = worker['globals']