程序不执行完全,在中间停止

时间:2011-02-15 01:56:57

标签: python dictionary service

from brisa.core.reactors import install_default_reactor

reactor = install_default_reactor()
print reactor

from brisa.core.threaded_call import run_async_function

from brisa.upnp.control_point.control_point import ControlPoint

from datetime import datetime

service = ('u', 'urn:schemas-upnp-org:service:SwitchPower:1')

binary_light_type = 'urn:schemas-upnp-org:device:BinaryLight:1'

def on_new_device(dev):

    print 'Got new device:', dev.udn

    print "Type 'list' to see the whole list"

    if not dev:
            return

def get_switch_service(device):

    return device.services[service[1]]

def create_control_point():

    c = ControlPoint()

    print "hello"   

    c.subscribe('new_device_event', on_new_device)  

    print "c"

    return c

def main():

    """ Main loop iteration receiving input commands.

    """

    print "hell"

    c = create_control_point()
    print "helllo"

    c.start()

    run_async_function(_handle_cmds, (c, ))

    reactor.add_after_stop_func(c.stop)

    reactor.main()

def _exit(c):

    """ Stops the _handle_cmds loop

    """

    global running_handle_cmds

    running_handle_cmds = False

def _search(c):

    """ Start searching for devices of type upnp:rootdevice and repeat

    search every 600 seconds (UPnP default)

    """

    c.start_search(600, 'upnp:rootdevice')


def _get_status(c):

    """ Gets the binary light status and print if it's on or off.

    """

    try:

        service = get_switch_service(c.current_server)

        status_response = service.GetStatus()

        if status_response['ResultStatus'] == '1':

            print 'Binary light status is on'

        else:

            print 'Binary light status is off'

    except Exception, e:

        if not hasattr(c, 'current_server') or not c.current_server:

            print 'BinaryLight device not set.Please use set_light <n>'

        else:

            print 'Error in get_status():', e

def _get_target(c):

    """ Gets the binary light target and print if it's on or off.

    """

    try:

        service = get_switch_service(c.current_server)

        status_response = service.GetTarget()

        if status_response['RetTargetValue'] == '1':

            print 'Binary light target is on'

        else:

            print 'Binary light target is off'

    except Exception, e:

        if not hasattr(c, 'current_server') or not c.current_server:

            print 'BinaryLight device not set.Please use set_light <n>'

        else:

            print 'Error in get_target():', e

def _stop(c):

    """ Stop searching

    """

    c.stop_search()

def _list_devices(c):

    """ Lists the devices that are in network.

    """

    k = 0

    for d in c.get_devices().values():

        print 'Device no.:', k

        print 'UDN:', d.udn

        print 'Name:', d.friendly_name

        print 'Device type:', d.device_type

        print 'Services:', d.services.keys() # Only print services name

        print

        k += 1

if __name__ == '__main__':
    print "hello"

    main()

我收到了输出:

ankit @ ubuntu:〜/ Desktop $ python controlpt.py

<brisa.core.reactors.glib2.GLib2Reactor object at 0x88c3e0c>
hello
hell

它不会转到c = create_control_point行。这是为什么?请指导我删除此错误。

1 个答案:

答案 0 :(得分:0)

我不熟悉这个'brisa'图书馆。我会收集到,由于某种原因,ControlPoint构造函数使用sys.exit()退出整个程序(或调用一些等效的C代码)。

在命令行上运行程序,如下所示:

$ python
>>> import controlpt
>>> controlpt.main()

然后你应该能够看到它是否真的退出了整个过程。如果它将您转回&gt;&gt;&gt;提示,然后我不知道发生了什么。但如果它完全退出Python,则意味着ControlPoint构造函数正在退出。