connection.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #
  2. # Analogue of `multiprocessing.connection` which uses queues instead of sockets
  3. #
  4. # multiprocessing/dummy/connection.py
  5. #
  6. # Copyright (c) 2006-2008, R Oudkerk
  7. # All rights reserved.
  8. #
  9. # Redistribution and use in source and binary forms, with or without
  10. # modification, are permitted provided that the following conditions
  11. # are met:
  12. #
  13. # 1. Redistributions of source code must retain the above copyright
  14. # notice, this list of conditions and the following disclaimer.
  15. # 2. Redistributions in binary form must reproduce the above copyright
  16. # notice, this list of conditions and the following disclaimer in the
  17. # documentation and/or other materials provided with the distribution.
  18. # 3. Neither the name of author nor the names of any contributors may be
  19. # used to endorse or promote products derived from this software
  20. # without specific prior written permission.
  21. #
  22. # THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS "AS IS" AND
  23. # ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  24. # IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  25. # ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
  26. # FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  27. # DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  28. # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  29. # HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  30. # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  31. # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  32. # SUCH DAMAGE.
  33. #
  34. __all__ = [ 'Client', 'Listener', 'Pipe' ]
  35. from Queue import Queue
  36. families = [None]
  37. class Listener(object):
  38. def __init__(self, address=None, family=None, backlog=1):
  39. self._backlog_queue = Queue(backlog)
  40. def accept(self):
  41. return Connection(*self._backlog_queue.get())
  42. def close(self):
  43. self._backlog_queue = None
  44. address = property(lambda self: self._backlog_queue)
  45. def Client(address):
  46. _in, _out = Queue(), Queue()
  47. address.put((_out, _in))
  48. return Connection(_in, _out)
  49. def Pipe(duplex=True):
  50. a, b = Queue(), Queue()
  51. return Connection(a, b), Connection(b, a)
  52. class Connection(object):
  53. def __init__(self, _in, _out):
  54. self._out = _out
  55. self._in = _in
  56. self.send = self.send_bytes = _out.put
  57. self.recv = self.recv_bytes = _in.get
  58. def poll(self, timeout=0.0):
  59. if self._in.qsize() > 0:
  60. return True
  61. if timeout <= 0.0:
  62. return False
  63. self._in.not_empty.acquire()
  64. self._in.not_empty.wait(timeout)
  65. self._in.not_empty.release()
  66. return self._in.qsize() > 0
  67. def close(self):
  68. pass