1

我正在为 xbmc 开发 python 服务,但我陷入了绝望。XBMC 具有通过 JSON-RPC 进行通信的 TCP API。XBMC 有服务器 TCP 套接字,主要用于接收命令和响应,但如果系统发生某些事情,它会向 TCP 发送“通知”。问题是我需要创建行为类似于服务器的 TCP 客户端,因此它能够接收此“通知”。无论我在哪里运行socket.recv(4096)它都会等待数据并卡住我的代码,因为我需要循环我的代码。代码结构基本上是这样的:

import xbmc, xbmcgui, xbmcaddon

class XPlayer(xbmc.Player) :   
    def __init__ (self):
        xbmc.Player.__init__(self)
    def onPlayBackStarted(self):
        if xbmc.Player().isPlayingVideo():
            doPlayBackStartedStuff()

player=XPlayer()
doStartupStuff()

while (not xbmc.abortRequested):
    if xbmc.Player().isPlayingVideo():
        doPlayingVideoStuff()
    else:
        doPlayingEverythingElseStuff()

    xbmc.sleep(500)
    # This loop is the most essential part of code

if (xbmc.abortRequested):
    closeEverything()
    xbmc.log('Aborting...')

我尝试了所有线程,多处理,阻塞,非阻塞,没有任何帮助。谢谢,

4

1 回答 1

1

您可能需要 select()、poll() 或 epoll(): http ://docs.python.org/library/select.html

这个 Python pipe-progress-meter 应用程序使用 select,例如: http ://stromberg.dnsalias.org/~strombrg/reblock.html

如果您知道什么样的分隔符分隔协议的各个部分,您可能还会发现这很有用,不需要 select 或类似的: http ://stromberg.dnsalias.org/~strombrg/bufsock.html 它处理得很好优雅地使用“读取下一个空字节”、“读取最多 100 个字节”等。

于 2012-07-03T20:51:37.363 回答