Event.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. <?php
  2. /**
  3. * This file is part of workerman.
  4. *
  5. * Licensed under The MIT License
  6. * For full copyright and license information, please see the MIT-LICENSE.txt
  7. * Redistributions of files must retain the above copyright notice.
  8. *
  9. * @author 有个鬼<42765633@qq.com>
  10. * @copyright 有个鬼<42765633@qq.com>
  11. * @link http://www.workerman.net/
  12. * @license http://www.opensource.org/licenses/mit-license.php MIT License
  13. */
  14. namespace Workerman\Events;
  15. /**
  16. * libevent eventloop
  17. */
  18. class Event implements EventInterface
  19. {
  20. /**
  21. * Event base.
  22. * @var object
  23. */
  24. protected $_eventBase = null;
  25. /**
  26. * All listeners for read/write event.
  27. * @var array
  28. */
  29. protected $_allEvents = array();
  30. /**
  31. * Event listeners of signal.
  32. * @var array
  33. */
  34. protected $_eventSignal = array();
  35. /**
  36. * All timer event listeners.
  37. * [func, args, event, flag, time_interval]
  38. * @var array
  39. */
  40. protected $_eventTimer = array();
  41. /**
  42. * Timer id.
  43. * @var int
  44. */
  45. protected static $_timerId = 1;
  46. /**
  47. * construct
  48. * @return void
  49. */
  50. public function __construct()
  51. {
  52. $this->_eventBase = new \EventBase();
  53. }
  54. /**
  55. * @see EventInterface::add()
  56. */
  57. public function add($fd, $flag, $func, $args=array())
  58. {
  59. switch ($flag) {
  60. case self::EV_SIGNAL:
  61. $fd_key = (int)$fd;
  62. $event = \Event::signal($this->_eventBase, $fd, $func);
  63. if (!$event||!$event->add()) {
  64. return false;
  65. }
  66. $this->_eventSignal[$fd_key] = $event;
  67. return true;
  68. case self::EV_TIMER:
  69. case self::EV_TIMER_ONCE:
  70. $param = array($func, (array)$args, $flag, $fd, self::$_timerId);
  71. $event = new \Event($this->_eventBase, -1, \Event::TIMEOUT|\Event::PERSIST, array($this, "timerCallback"), $param);
  72. if (!$event||!$event->addTimer($fd)) {
  73. return false;
  74. }
  75. $this->_eventTimer[self::$_timerId] = $event;
  76. return self::$_timerId++;
  77. default :
  78. $callback = function ($fd) use ($func) {
  79. try {
  80. call_user_func($func, $fd);
  81. } catch (\Exception $e) {
  82. echo $e;
  83. exit(250);
  84. }
  85. };
  86. $fd_key = (int)$fd;
  87. $real_flag = $flag === self::EV_READ ? \Event::READ | \Event::PERSIST : \Event::WRITE | \Event::PERSIST;
  88. $event = new \Event($this->_eventBase, $fd, $real_flag, $callback);
  89. if (!$event||!$event->add()) {
  90. return false;
  91. }
  92. $this->_allEvents[$fd_key][$flag] = $event;
  93. return true;
  94. }
  95. }
  96. /**
  97. * @see Events\EventInterface::del()
  98. */
  99. public function del($fd, $flag)
  100. {
  101. switch ($flag) {
  102. case self::EV_READ:
  103. case self::EV_WRITE:
  104. $fd_key = (int)$fd;
  105. if (isset($this->_allEvents[$fd_key][$flag])) {
  106. $this->_allEvents[$fd_key][$flag]->del();
  107. unset($this->_allEvents[$fd_key][$flag]);
  108. }
  109. if (empty($this->_allEvents[$fd_key])) {
  110. unset($this->_allEvents[$fd_key]);
  111. }
  112. break;
  113. case self::EV_SIGNAL:
  114. $fd_key = (int)$fd;
  115. if (isset($this->_eventSignal[$fd_key])) {
  116. $this->_allEvents[$fd_key][$flag]->del();
  117. unset($this->_eventSignal[$fd_key]);
  118. }
  119. break;
  120. case self::EV_TIMER:
  121. case self::EV_TIMER_ONCE:
  122. if (isset($this->_eventTimer[$fd])) {
  123. $this->_eventTimer[$fd]->del();
  124. unset($this->_eventTimer[$fd]);
  125. }
  126. break;
  127. }
  128. return true;
  129. }
  130. /**
  131. * Timer callback.
  132. * @param null $fd
  133. * @param int $what
  134. * @param int $timer_id
  135. */
  136. public function timerCallback($fd, $what, $param)
  137. {
  138. $timer_id = $param[4];
  139. if ($param[2] === self::EV_TIMER_ONCE) {
  140. $this->_eventTimer[$timer_id]->del();
  141. unset($this->_eventTimer[$timer_id]);
  142. }
  143. try {
  144. call_user_func_array($param[0], $param[1]);
  145. } catch (\Exception $e) {
  146. echo $e;
  147. exit(250);
  148. }
  149. }
  150. /**
  151. * @see Events\EventInterface::clearAllTimer()
  152. * @return void
  153. */
  154. public function clearAllTimer()
  155. {
  156. foreach ($this->_eventTimer as $event) {
  157. $event->del();
  158. }
  159. $this->_eventTimer = array();
  160. }
  161. /**
  162. * @see EventInterface::loop()
  163. */
  164. public function loop()
  165. {
  166. $this->_eventBase->loop();
  167. }
  168. }