本文整理匯總了Python中contextvars.copy_context方法的典型用法代碼示例。如果您正苦於以下問題:Python contextvars.copy_context方法的具體用法?Python contextvars.copy_context怎麽用?Python contextvars.copy_context使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類contextvars
的用法示例。
在下文中一共展示了contextvars.copy_context方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: run_sync
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def run_sync(func: Callable[..., Any]) -> Callable[..., Coroutine[Any, None, None]]:
"""Ensure that the sync function is run within the event loop.
If the *func* is not a coroutine it will be wrapped such that
it runs in the default executor (use loop.set_default_executor
to change). This ensures that synchronous functions do not
block the event loop.
"""
@wraps(func)
async def _wrapper(*args: Any, **kwargs: Any) -> Any:
loop = asyncio.get_running_loop()
result = await loop.run_in_executor(
None, copy_context().run, partial(func, *args, **kwargs)
)
if isgenerator(result):
return run_sync_iterable(result) # type: ignore
else:
return result
_wrapper._quart_async_wrapper = True # type: ignore
return _wrapper
示例2: run_sync_iterable
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def run_sync_iterable(iterable: Generator[Any, None, None]) -> AsyncGenerator[Any, None]:
async def _gen_wrapper() -> AsyncGenerator[Any, None]:
# Wrap the generator such that each iteration runs
# in the executor. Then rationalise the raised
# errors so that it ends.
def _inner() -> Any:
# https://bugs.python.org/issue26221
# StopIteration errors are swallowed by the
# run_in_exector method
try:
return next(iterable)
except StopIteration:
raise StopAsyncIteration()
loop = asyncio.get_running_loop()
while True:
try:
yield await loop.run_in_executor(None, copy_context().run, _inner)
except StopAsyncIteration:
return
return _gen_wrapper()
示例3: __init__
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def __init__(self, coro, *, loop=None):
super().__init__(loop=loop)
if self._source_traceback:
del self._source_traceback[-1]
if not coroutines.iscoroutine(coro):
# raise after Future.__init__(), attrs are required for __del__
# prevent logging for pending task in __del__
self._log_destroy_pending = False
raise TypeError(f"a coroutine was expected, got {coro!r}")
self._must_cancel = False
self._fut_waiter = None
self._coro = coro
self._context = contextvars.copy_context()
self._loop.call_soon(self.__step, context=self._context)
_register_task(self)
示例4: __call__
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def __call__(self, *args, **kwargs):
# re-implementation of sync_to_async
loop = asyncio.get_event_loop()
context = contextvars.copy_context()
child = functools.partial(self.func, *args, **kwargs)
future = loop.run_in_executor(
self.executor,
functools.partial(
self.thread_handler,
loop,
self.get_current_task(),
sys.exc_info(),
context.run,
child,
),
)
return await asyncio.wait_for(future, timeout=None)
# The class is TitleCased, but we want to encourage use as a callable/decorator
示例5: submit_to_executor
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def submit_to_executor(func: Callable, *args, **kwargs) -> Future:
"""
Submit a callable to the current context's executor pool and
get back a future to monitor execution.
Parameters
----------
func : Callable
Callable to be executed
args
Positional arguments to func
kwargs
Keyword arguments to func
Returns
-------
Future
"""
current_context = copy_context()
return get_executor().submit(current_context.run, func, *args, **kwargs)
示例6: threader
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def threader():
threads = []
def start_fn(delay, fn):
def thread_fn():
time.sleep(delay)
fn()
target = functools.partial(contextvars.copy_context().run, thread_fn)
thread = threading.Thread(target=target)
thread.start()
threads.append(thread)
try:
yield start_fn
finally:
for thread in threads:
thread.join()
示例7: test_context_run_4
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def test_context_run_4(self):
ctx1 = contextvars.Context()
ctx2 = contextvars.Context()
var = contextvars.ContextVar('var')
def func2():
self.assertIsNone(var.get(None))
def func1():
self.assertIsNone(var.get(None))
var.set('spam')
ctx2.run(func2)
self.assertEqual(var.get(None), 'spam')
cur = contextvars.copy_context()
self.assertEqual(len(cur), 1)
self.assertEqual(cur[var], 'spam')
return cur
returned_ctx = ctx1.run(func1)
self.assertEqual(ctx1, returned_ctx)
self.assertEqual(returned_ctx[var], 'spam')
self.assertIn(var, returned_ctx)
示例8: inner
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def inner(self, x):
self.assertEqual(ctx_var.get(), x)
await self.gen_inner(x)
self.assertEqual(ctx_var.get(), x)
# IOLoop.run_in_executor doesn't automatically copy context
ctx = contextvars.copy_context()
await self.io_loop.run_in_executor(None, lambda: ctx.run(self.thread_inner, x))
self.assertEqual(ctx_var.get(), x)
# Neither does asyncio's run_in_executor.
await asyncio.get_event_loop().run_in_executor(
None, lambda: ctx.run(self.thread_inner, x)
)
self.assertEqual(ctx_var.get(), x)
示例9: add_done_callback
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def add_done_callback(self, fn, *, context=None):
"""Add a callback to be run when the future becomes done.
The callback is called with a single argument - the future object. If
the future is already done when this is called, the callback is
scheduled with call_soon.
"""
if self._state != _PENDING:
self._loop.call_soon(fn, self, context=context)
else:
if context is None:
context = contextvars.copy_context()
self._callbacks.append((fn, context))
# New method not in PEP 3148.
示例10: __init__
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def __init__(self, callback, args, loop, context=None):
if context is None:
context = contextvars.copy_context()
self._context = context
self._loop = loop
self._callback = callback
self._args = args
self._cancelled = False
self._repr = None
if self._loop.get_debug():
self._source_traceback = format_helpers.extract_stack(
sys._getframe(1))
else:
self._source_traceback = None
示例11: __init__
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def __init__(self, *, loop, source, repeat, callback, args, context=None):
super().__init__(callback, args, loop)
if sys.version_info[:2] >= (3, 7) and context is None:
import contextvars
context = contextvars.copy_context()
self._context = context
self._source = source
self._repeat = repeat
loop._handlers.add(self)
source.set_callback(self.__callback__, self)
source.attach(loop._context)
示例12: init_stack
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def init_stack(self, generator):
"""Create a new stack for the given generator."""
self._contexts[generator] = copy_context()
示例13: schedule
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def schedule(self, x, context_map=None):
"""Schedule a task."""
if context_map:
ctx = copy_context()
ctx.run(lambda: [k.set(v) for k, v in context_map.items()])
fut = ctx.run(asyncio.ensure_future, x, loop=self)
else:
fut = asyncio.ensure_future(x, loop=self)
self._tasks.append(fut)
return fut
示例14: run_in_executor_with_context
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def run_in_executor_with_context(
func: Callable[..., _T], *args: Any, loop: Optional[AbstractEventLoop] = None
) -> Awaitable[_T]:
"""
Run a function in an executor, but make sure it uses the same contextvars.
This is required so that the function will see the right application.
See also: https://bugs.python.org/issue34014
"""
loop = loop or get_event_loop()
ctx: contextvars.Context = contextvars.copy_context()
return loop.run_in_executor(None, ctx.run, func, *args)
示例15: __init__
# 需要導入模塊: import contextvars [as 別名]
# 或者: from contextvars import copy_context [as 別名]
def __init__(self,
work,
args=(),
kw={},
max=100,
title=None,
tags=None,
comment='',
auto_save=None,
no_bar=False):
title = work.__name__ if title is None else title
self.ctx = contextvars.copy_context()
self.parent = self.ctx.get(current_job, None)
if auto_save is None:
self.auto_save = True if self.parent is None else False
else:
self.auto_save = auto_save
self.data = DataCollector(title, tags=tags, comment=comment, job=self)
self.bar = ProgressBar(max=max, description=title, hiden=no_bar)
self.out = widgets.Output()
display(self.out)
self.work_code = None
code = compile(inspect.getsource(work),
f'defintion of {work.__name__}', 'single')
for c in code.co_consts:
if isinstance(c, type(code)) and c.co_name == work.__name__:
self.work_code = c
break
self.work = work
self.args = args
self.kw = kw