2012-08-09 100 views
3

我写了(主要是复制)一个非常简单的python脚本,作为xbmc的Caller ID插件。除了关闭套接字外,它可以按预期工作。我已经确认xbmc.abortRequested(XBMC正在关闭的通知)确实被设置为True,因此循环应该结束。但它没有(它似乎挂起),xbmc在清理过程中约5秒后杀死脚本。这种不合理的退出并不会引起任何问题,但我宁愿让脚本正常退出。我无法弄清楚是否有某种其他的超时可以设置或什么。谢谢你的帮助。asyncore套接字没有正确关闭

道格

我的代码:

import socket, threading, thread, sys, asyncore, xbmc, xbmcgui, xbmcaddon 
from time import * 
from string import * 

xbmc.log("YAC Listener: Starting") 
PORT = 10629 

class Server(asyncore.dispatcher): 
    def __init__(self, host, port): 
     asyncore.dispatcher.__init__(self) 
     self.create_socket(socket.AF_INET, socket.SOCK_STREAM) 
     self.bind((host, port)) 
     self.listen(1) 

    def handle_accept(self): 
     socket, address = self.accept() 
     ConnectionHandler(socket) 

    def handle_close(self): 
     self.close() 
     xbmc.log("YAC Listener: Closing Port") 

class ConnectionHandler(asyncore.dispatcher_with_send): 
    def handle_read(self): 
     self.buffer = self.recv(1024) 
     self.buffer = split(self.buffer[5:], "~") 
     self.close() 
     global data 
     if len(self.buffer) > 1: 
      name = self.buffer[0] 
      number = self.buffer[1] 
       xbmc.executebuiltin("XBMC.Notification("+name+","+number+",7000,special://home/addons/script.yaclistener/phone.png)") 
     else: 
      data = self.buffer 

s = Server('', PORT) 

while not xbmc.abortRequested: 
    asyncore.loop(timeout=1) 

s.close() 
sys.exit() 
xbmc.log("YAC Listener: Exiting") 

回答

1

“超时” 具有稍微不同的含义(大致可被视为一个环粒度)。

所以最终文件的代码应该像水木清华象下面这样:

... 
while not xbmc.abortRequested: 
    asyncore.loop(timeout=1, count=1) 

# this will try to close ALL current connections: 
asyncore.close_all() 
# this will give some time (up to 5 seconds) for things to settle down: 
asyncore.loop(timeout=1, count=5) 
sys.exit() 
xbmc.log("YAC Listener: Exiting")