當前位置: 首頁>>代碼示例>>Python>>正文


Python stack_context.wrap方法代碼示例

本文整理匯總了Python中tornado.stack_context.wrap方法的典型用法代碼示例。如果您正苦於以下問題:Python stack_context.wrap方法的具體用法?Python stack_context.wrap怎麽用?Python stack_context.wrap使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在tornado.stack_context的用法示例。


在下文中一共展示了stack_context.wrap方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: _handle_connect

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def _handle_connect(self):
        # Call the superclass method to check for errors.
        super(SSLIOStream, self)._handle_connect()
        if self.closed():
            return
        # When the connection is complete, wrap the socket for SSL
        # traffic.  Note that we do this by overriding _handle_connect
        # instead of by passing a callback to super().connect because
        # user callbacks are enqueued asynchronously on the IOLoop,
        # but since _handle_events calls _handle_connect immediately
        # followed by _handle_write we need this to be synchronous.
        #
        # The IOLoop will get confused if we swap out self.socket while the
        # fd is registered, so remove it now and re-register after
        # wrap_socket().
        self.io_loop.remove_handler(self.socket)
        old_state = self._state
        self._state = None
        self.socket = ssl_wrap_socket(self.socket, self._ssl_options,
                                      server_hostname=self._server_hostname,
                                      do_handshake_on_connect=False)
        self._add_io_state(old_state) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:24,代碼來源:iostream.py

示例2: set_exit_callback

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def set_exit_callback(self, callback):
        """Runs ``callback`` when this process exits.

        The callback takes one argument, the return code of the process.

        This method uses a ``SIGCHLD`` handler, which is a global setting
        and may conflict if you have other libraries trying to handle the
        same signal.  If you are using more than one ``IOLoop`` it may
        be necessary to call `Subprocess.initialize` first to designate
        one ``IOLoop`` to run the signal handlers.

        In many cases a close callback on the stdout or stderr streams
        can be used as an alternative to an exit callback if the
        signal handler is causing a problem.
        """
        self._exit_callback = stack_context.wrap(callback)
        Subprocess.initialize(self.io_loop)
        Subprocess._waiting[self.pid] = self
        Subprocess._try_cleanup_process(self.pid) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:21,代碼來源:process.py

示例3: test_pre_wrap_with_args

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def test_pre_wrap_with_args(self):
        # Same as test_pre_wrap, but the function takes arguments.
        # Implementation note: The function must not be wrapped in a
        # functools.partial until after it has been passed through
        # stack_context.wrap
        def f1(foo, bar):
            self.assertIn('c1', self.active_contexts)
            self.assertNotIn('c2', self.active_contexts)
            self.stop((foo, bar))

        with StackContext(functools.partial(self.context, 'c1')):
            wrapped = wrap(f1)

        with StackContext(functools.partial(self.context, 'c2')):
            self.add_callback(wrapped, 1, bar=2)

        result = self.wait()
        self.assertEqual(result, (1, 2)) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:20,代碼來源:ioloop_test.py

示例4: write

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def write(self, chunk, callback=None):
        """Implements `.HTTPConnection.write`.

        For backwards compatibility is is allowed but deprecated to
        skip `write_headers` and instead call `write()` with a
        pre-encoded header block.
        """
        future = None
        if self.stream.closed():
            future = self._write_future = Future()
            self._write_future.set_exception(iostream.StreamClosedError())
            self._write_future.exception()
        else:
            if callback is not None:
                self._write_callback = stack_context.wrap(callback)
            else:
                future = self._write_future = Future()
            self._pending_write = self.stream.write(self._format_chunk(chunk))
            self._pending_write.add_done_callback(self._on_write_complete)
        return future 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:22,代碼來源:http1connection.py

示例5: __init__

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def __init__(self, stream, address, request_callback, no_keep_alive=False,
                 xheaders=False, protocol=None):
        self.stream = stream
        self.address = address
        # Save the socket's address family now so we know how to
        # interpret self.address even after the stream is closed
        # and its socket attribute replaced with None.
        self.address_family = stream.socket.family
        self.request_callback = request_callback
        self.no_keep_alive = no_keep_alive
        self.xheaders = xheaders
        self.protocol = protocol
        self._clear_request_state()
        # Save stack context here, outside of any request.  This keeps
        # contexts from one request from leaking into the next.
        self._header_callback = stack_context.wrap(self._on_headers)
        self.stream.set_close_callback(self._on_connection_close)
        self.stream.read_until(b"\r\n\r\n", self._header_callback) 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:20,代碼來源:httpserver.py

示例6: read_until_close

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def read_until_close(self, callback, streaming_callback=None):
        """Reads all data from the socket until it is closed.

        If a ``streaming_callback`` is given, it will be called with chunks
        of data as they become available, and the argument to the final
        ``callback`` will be empty.  Otherwise, the ``callback`` gets the
        data as an argument.

        Subject to ``max_buffer_size`` limit from `IOStream` constructor if
        a ``streaming_callback`` is not used.
        """
        self._set_read_callback(callback)
        self._streaming_callback = stack_context.wrap(streaming_callback)
        if self.closed():
            if self._streaming_callback is not None:
                self._run_callback(self._streaming_callback,
                                   self._consume(self._read_buffer_size))
            self._run_callback(self._read_callback,
                               self._consume(self._read_buffer_size))
            self._streaming_callback = None
            self._read_callback = None
            return
        self._read_until_close = True
        self._streaming_callback = stack_context.wrap(streaming_callback)
        self._try_inline_read() 
開發者ID:viewfinderco,項目名稱:viewfinder,代碼行數:27,代碼來源:iostream.py

示例7: call_wrapped_inner

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def call_wrapped_inner(self, queue, count):
        if count < 0:
            return
        with self.make_context():
            queue.append(stack_context.wrap(
                functools.partial(self.call_wrapped_inner, queue, count - 1))) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:8,代碼來源:stack_context_benchmark.py

示例8: body_producer

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def body_producer(self, value):
        self._body_producer = stack_context.wrap(value) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:4,代碼來源:httpclient.py

示例9: streaming_callback

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def streaming_callback(self, value):
        self._streaming_callback = stack_context.wrap(value) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:4,代碼來源:httpclient.py

示例10: header_callback

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def header_callback(self, value):
        self._header_callback = stack_context.wrap(value) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:4,代碼來源:httpclient.py

示例11: add_handler

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def add_handler(self, fd, handler, events):
        if fd in self.fds:
            raise ValueError('fd %s added twice' % fd)
        fd, fileobj = self.split_fd(fd)
        self.fds[fd] = _FD(fd, fileobj, wrap(handler))
        if events & tornado.ioloop.IOLoop.READ:
            self.fds[fd].reading = True
            self.reactor.addReader(self.fds[fd])
        if events & tornado.ioloop.IOLoop.WRITE:
            self.fds[fd].writing = True
            self.reactor.addWriter(self.fds[fd]) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:13,代碼來源:twisted.py

示例12: add_timeout

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def add_timeout(self, deadline, callback, *args, **kwargs):
        # This method could be simplified (since tornado 4.0) by
        # overriding call_at instead of add_timeout, but we leave it
        # for now as a test of backwards-compatibility.
        if isinstance(deadline, numbers.Real):
            delay = max(deadline - self.time(), 0)
        elif isinstance(deadline, datetime.timedelta):
            delay = timedelta_to_seconds(deadline)
        else:
            raise TypeError("Unsupported deadline %r")
        return self.reactor.callLater(
            delay, self._run_callback,
            functools.partial(wrap(callback), *args, **kwargs)) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:15,代碼來源:twisted.py

示例13: add_callback

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def add_callback(self, callback, *args, **kwargs):
        self.reactor.callFromThread(
            self._run_callback,
            functools.partial(wrap(callback), *args, **kwargs)) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:6,代碼來源:twisted.py

示例14: add_handler

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def add_handler(self, fd, handler, events):
        fd, fileobj = self.split_fd(fd)
        if fd in self.handlers:
            raise ValueError("fd %s added twice" % fd)
        self.handlers[fd] = (fileobj, stack_context.wrap(handler))
        if events & IOLoop.READ:
            self.asyncio_loop.add_reader(
                fd, self._handle_events, fd, IOLoop.READ)
            self.readers.add(fd)
        if events & IOLoop.WRITE:
            self.asyncio_loop.add_writer(
                fd, self._handle_events, fd, IOLoop.WRITE)
            self.writers.add(fd) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:15,代碼來源:asyncio.py

示例15: call_at

# 需要導入模塊: from tornado import stack_context [as 別名]
# 或者: from tornado.stack_context import wrap [as 別名]
def call_at(self, when, callback, *args, **kwargs):
        # asyncio.call_at supports *args but not **kwargs, so bind them here.
        # We do not synchronize self.time and asyncio_loop.time, so
        # convert from absolute to relative.
        return self.asyncio_loop.call_later(
            max(0, when - self.time()), self._run_callback,
            functools.partial(stack_context.wrap(callback), *args, **kwargs)) 
開發者ID:tao12345666333,項目名稱:tornado-zh,代碼行數:9,代碼來源:asyncio.py


注:本文中的tornado.stack_context.wrap方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。