0

PyOSC 非常有礼貌地处理各种异常,但不幸的是使其难以调试。我该如何打败这个?

例如,我有一个编码错误,它报告为:

OSCServer: NameError on request from localhost:50542: global name 'cell' is not defined

通常在 python 中,这会抛出一个带有有用跟踪的异常。但在 PyOSC 中,这就是我所得到的。

如何关闭 PyOSC 的异常处理?

更新:一个月后,这个问题收到零评论或答案。猜猜使用 Python、开放式声音控制和 PyOSC 模块的人并不多。我终于在下面回答了我自己的问题。

4

1 回答 1

0

好吧,我想通了。由于 PyOSC 的文档很少,因此源代码用作文档。

这是捕获异常的代码:

def handle_error(self, request, client_address):
    """Handle an exception in the Server's callbacks gracefully.
    Writes the error to sys.stderr and, if the error_prefix (see setSrvErrorPrefix()) is set,
    sends the error-message as reply to the client
    """
    (e_type, e) = sys.exc_info()[:2]
    self.printErr("%s on request from %s: %s" % (e_type.__name__, getUrlStr(client_address), str(e)))

    if self.print_tracebacks:
        import traceback
        traceback.print_exc() # XXX But this goes to stderr!

    if len(self.error_prefix):
        self.sendOSCerror("%s: %s" % (e_type.__name__, str(e)), client_address)

这是在创建 OSCServer 实例时打开跟踪的简单方法:

import OSC

myoscserver = OSC.OSCServer( (host, port) )
myoscserver.print_tracebacks = True

这也适用于 OSCClient:

myoscclient = OSC.OSCClient()
myoscclient.connect( (host, port) )
myoscclient.print_tracebacks = True

希望有帮助。

于 2014-05-20T22:49:15.883 回答