##// END OF EJS Templates
work, cleanup
Matthias Bussonnier -
Show More
@@ -139,7 +139,6 class CachingCompiler(codeop.Compile):
139 def extra_flags(self, flags):
139 def extra_flags(self, flags):
140 old_flags = self.flags
140 old_flags = self.flags
141 self.flags = self.flags | flags
141 self.flags = self.flags | flags
142 print('flags', old_flags ,'->', self.flags)
143 try:
142 try:
144 yield
143 yield
145 finally:
144 finally:
@@ -3202,6 +3202,7 class InteractiveShell(SingletonConfigurable):
3202 raise ValueError("Interactivity was %r" % interactivity)
3202 raise ValueError("Interactivity was %r" % interactivity)
3203 try:
3203 try:
3204 if _async and sys.version_info < (3,8):
3204 if _async and sys.version_info < (3,8):
3205 raise ValueError
3205 # If interactivity is async the semantics of run_code are
3206 # If interactivity is async the semantics of run_code are
3206 # completely different Skip usual machinery.
3207 # completely different Skip usual machinery.
3207 mod = Module(nodelist, [])
3208 mod = Module(nodelist, [])
@@ -3211,18 +3212,26 class InteractiveShell(SingletonConfigurable):
3211 if (yield from self.run_code(async_code, result, async_=True)):
3212 if (yield from self.run_code(async_code, result, async_=True)):
3212 return True
3213 return True
3213 else:
3214 else:
3215 def compare(code):
3216 import inspect
3217 is_async = (inspect.CO_COROUTINE & code.co_flags == inspect.CO_COROUTINE)
3218 print('async=', _async, 'autodetect=', is_async)
3219 return is_async
3214 for i, node in enumerate(to_run_exec):
3220 for i, node in enumerate(to_run_exec):
3215 mod = Module([node], [])
3221 mod = Module([node], [])
3216 code = compiler(mod, cell_name, "exec")
3222 code = compiler(mod, cell_name, "exec")
3223 compare(code)
3217 if (yield from self.run_code(code, result)):
3224 if (yield from self.run_code(code, result)):
3218 return True
3225 return True
3219
3226
3220 for i, node in enumerate(to_run_interactive):
3227 for i, node in enumerate(to_run_interactive):
3221 print('B: interactive, async=', _async, nodelist)
3228 print('B: interactive, async=', _async, nodelist)
3222 mod = ast.Interactive([node])
3229 mod = ast.Interactive([node])
3223 with compiler.extra_flags(0x2000 if _async else 0x0):
3230 with compiler.extra_flags(ast.ast.PyCF_ALLOW_TOP_LEVEL_AWAIT if _async else 0x0):
3224 code = compiler(mod, cell_name, "single")
3231 code = compiler(mod, cell_name, "single")
3225 if (yield from self.run_code(code, result, async_=_async)):
3232 asy = compare(code)
3233
3234 if (yield from self.run_code(code, result, async_=asy)):
3226 return True
3235 return True
3227
3236
3228 # Flush softspace
3237 # Flush softspace
@@ -3298,7 +3307,7 class InteractiveShell(SingletonConfigurable):
3298 code = compile('last_expr', 'fake', "single")
3307 code = compile('last_expr', 'fake', "single")
3299 exec(code, {'last_expr': last_expr})
3308 exec(code, {'last_expr': last_expr})
3300 elif async_ :
3309 elif async_ :
3301 res = yield from eval(code_obj, self.user_ns)
3310 yield from eval(code_obj, self.user_global_ns, self.user_ns)
3302 else:
3311 else:
3303 exec(code_obj, self.user_global_ns, self.user_ns)
3312 exec(code_obj, self.user_global_ns, self.user_ns)
3304 finally:
3313 finally:
General Comments 0
You need to be logged in to leave comments. Login now