7dd95d8a59
* chore: auto fix by ruff * refactor: 统一修正返回类型注解为 None/bool 以匹配实现 * refactor: 将 _get_next_page 改为异步并移除多余的请求错误抛出 * refactor: 将 get_client 的返回类型改为 object * style: 为 LarkMessageEvent 的相关方法添加返回类型注解 None --------- Co-authored-by: Soulter <37870767+Soulter@users.noreply.github.com>
37 lines
907 B
Python
37 lines
907 B
Python
import os
|
|
import threading
|
|
from logging import Logger
|
|
|
|
|
|
class LogPipe(threading.Thread):
|
|
def __init__(
|
|
self,
|
|
level,
|
|
logger: Logger,
|
|
identifier=None,
|
|
callback=None,
|
|
) -> None:
|
|
threading.Thread.__init__(self)
|
|
self.daemon = True
|
|
self.level = level
|
|
self.fd_read, self.fd_write = os.pipe()
|
|
self.identifier = identifier
|
|
self.logger = logger
|
|
self.callback = callback
|
|
self.reader = os.fdopen(self.fd_read)
|
|
self.start()
|
|
|
|
def fileno(self):
|
|
return self.fd_write
|
|
|
|
def run(self) -> None:
|
|
for line in iter(self.reader.readline, ""):
|
|
if self.callback:
|
|
self.callback(line.strip())
|
|
self.logger.log(self.level, f"[{self.identifier}] {line.strip()}")
|
|
|
|
self.reader.close()
|
|
|
|
def close(self) -> None:
|
|
os.close(self.fd_write)
|