Server IP : 192.64.118.117 / Your IP : 18.190.219.46 Web Server : LiteSpeed System : Linux premium56.web-hosting.com 4.18.0-513.24.1.lve.1.el8.x86_64 #1 SMP Thu May 9 15:10:09 UTC 2024 x86_64 User : thecgapy ( 1160) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /opt/hc_python/lib64/python3.12/site-packages/greenlet/tests/ |
Upload File : |
# -*- coding: utf-8 -*- """ If we have a run callable passed to the constructor or set as an attribute, but we don't actually use that (because ``__getattribute__`` or the like interferes), then when we clear callable before beginning to run, there's an opportunity for Python code to run. """ import greenlet g = None main = greenlet.getcurrent() results = [] class RunCallable: def __del__(self): results.append(('RunCallable', '__del__')) main.switch('from RunCallable') class G(greenlet.greenlet): def __getattribute__(self, name): if name == 'run': results.append(('G.__getattribute__', 'run')) return run_func return object.__getattribute__(self, name) def run_func(): results.append(('run_func', 'enter')) g = G(RunCallable()) # Try to start G. It will get to the point where it deletes # its run callable C++ variable in inner_bootstrap. That triggers # the __del__ method, which switches back to main before g # actually even starts running. x = g.switch() results.append(('main: g.switch()', x)) # In the C++ code, this results in g->g_switch() appearing to return, even though # it has yet to run. print('In main with', x, flush=True) g.switch() print('RESULTS', results)