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


PHP MainLogger::getMessages方法代碼示例

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


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

示例1: run

 public function run()
 {
     while ($this->stop !== true) {
         $this->synchronized(function () {
             $this->wait(2000);
         });
         $r = [$socket = $this->socket];
         $w = null;
         $e = null;
         if (socket_select($r, $w, $e, 0) === 1) {
             if (($client = socket_accept($this->socket)) !== false) {
                 socket_set_block($client);
                 socket_set_option($client, SOL_SOCKET, SO_KEEPALIVE, 1);
                 $done = false;
                 for ($n = 0; $n < $this->maxClients; ++$n) {
                     if ($this->{"client" . $n} === null) {
                         $this->{"client" . $n} = $client;
                         $this->{"status" . $n} = 0;
                         $this->{"timeout" . $n} = microtime(true) + 5;
                         $done = true;
                         break;
                     }
                 }
                 if ($done === false) {
                     @socket_close($client);
                 }
             }
         }
         for ($n = 0; $n < $this->maxClients; ++$n) {
             $client =& $this->{"client" . $n};
             if ($client !== null) {
                 if ($this->{"status" . $n} !== -1 and $this->stop !== true) {
                     if ($this->{"status" . $n} === 0 and $this->{"timeout" . $n} < microtime(true)) {
                         //Timeout
                         $this->{"status" . $n} = -1;
                         continue;
                     }
                     $p = $this->readPacket($client, $size, $requestID, $packetType, $payload);
                     if ($p === false) {
                         $this->{"status" . $n} = -1;
                         continue;
                     } elseif ($p === null) {
                         continue;
                     }
                     switch ($packetType) {
                         case 9:
                             //Protocol check
                             if ($this->{"status" . $n} !== 1) {
                                 $this->{"status" . $n} = -1;
                                 continue;
                             }
                             $this->writePacket($client, $requestID, 0, RCON::PROTOCOL_VERSION);
                             $this->response = "";
                             if ($payload == RCON::PROTOCOL_VERSION) {
                                 $this->logger->setSendMsg(true);
                             }
                             //GeniRCON output
                             break;
                         case 4:
                             //Logger
                             if ($this->{"status" . $n} !== 1) {
                                 $this->{"status" . $n} = -1;
                                 continue;
                             }
                             $this->writePacket($client, $requestID, 0, str_replace("\n", "\r\n", trim($this->logger->getMessages())));
                             $this->response = "";
                             break;
                         case 3:
                             //Login
                             if ($this->{"status" . $n} !== 0) {
                                 $this->{"status" . $n} = -1;
                                 continue;
                             }
                             if ($payload === $this->password) {
                                 socket_getpeername($client, $addr, $port);
                                 $this->response = "[INFO] Successful Rcon connection from: /{$addr}:{$port}";
                                 $this->response = "";
                                 $this->writePacket($client, $requestID, 2, "");
                                 $this->{"status" . $n} = 1;
                             } else {
                                 $this->{"status" . $n} = -1;
                                 $this->writePacket($client, -1, 2, "");
                                 continue;
                             }
                             break;
                         case 2:
                             //Command
                             if ($this->{"status" . $n} !== 1) {
                                 $this->{"status" . $n} = -1;
                                 continue;
                             }
                             if (strlen($payload) > 0) {
                                 $this->cmd = ltrim($payload);
                                 $this->synchronized(function () {
                                     $this->waiting = true;
                                     $this->wait();
                                 });
                                 $this->waiting = false;
                                 $this->writePacket($client, $requestID, 0, str_replace("\n", "\r\n", trim($this->response)));
                                 $this->response = "";
//.........這裏部分代碼省略.........
開發者ID:xpyctum,項目名稱:Genisys,代碼行數:101,代碼來源:RCONInstance.php


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