53

NSWindowControllerを制御するNSWindowCocoaアプリがありNSComboBoxます。特別なことは何もなく、OS X 10.7.2 にアップグレードするまで問題なく動作していました。ウィンドウコントローラーのウィンドウが読み込まれると、次の例外が1回だけ発生します。(私のアプリのウィンドウ コントローラーは読み込まれたままなので、アプリの起動ごとに 1 回だけ発生します。) その後、コンボ ボックスにフォーカスを合わせたりフォーカスを外したりしても、コンボ ボックスはトリガーされません。

10.7.2 で何かが変更されたかどうかを知っている人はいますか?もしそうなら、それを回避する方法はありますか?

(これは Xcode 4.2 で発生しています。)

2011-10-24 11:30:21.649 MyApp[7934:707] Unlocking Focus on wrong view ((null)), expected <NSComboBox: 0x40083d6e0>
2011-10-24 11:30:21.653 MyApp[7934:707] (
    0   CoreFoundation    0x00007fff8412d286 __exceptionPreprocess + 198
    1   libobjc.A.dylib   0x00007fff88cdad5e objc_exception_throw + 43
    2   CoreFoundation    0x00007fff8412d0ba +[NSException raise:format:arguments:] + 106
    3   CoreFoundation    0x00007fff8412d044 +[NSException raise:format:] + 116
    4   AppKit            0x00007fff8c76c1d5 -[NSFocusStack unfocusView:] + 194
    5   AppKit            0x00007fff8c7e838e +[_NSAutomaticFocusRing showForView:] + 2545
    6   AppKit            0x00007fff8cdbb4d1 __postActiveFirstResponderChanged_block_invoke_1 + 32
    7   CoreFoundation    0x00007fff840ecf37 __CFRUNLOOP_IS_CALLING_OUT_TO_AN_OBSERVER_CALLBACK_FUNCTION__ + 23
    8   CoreFoundation    0x00007fff840ece96 __CFRunLoopDoObservers + 374
    9   CoreFoundation    0x00007fff840c2159 __CFRunLoopRun + 825
    10  CoreFoundation    0x00007fff840c1ae6 CFRunLoopRunSpecific + 230
    11  HIToolbox         0x00007fff8c0d73d3 RunCurrentEventLoopInMode + 277
    12  HIToolbox         0x00007fff8c0de58f ReceiveNextEventCommon + 181
    13  HIToolbox         0x00007fff8c0de4ca BlockUntilNextEventMatchingListInMode + 62
    14  AppKit            0x00007fff8c71e3f1 _DPSNextEvent + 659
    15  AppKit            0x00007fff8c71dcf5 -[NSApplication nextEventMatchingMask:untilDate:inMode:dequeue:] + 135
    16  AppKit            0x00007fff8c71a62d -[NSApplication run] + 470
    17  AppKit            0x00007fff8c99980c NSApplicationMain + 867
    18  MyApp             0x0000000100001682 main + 34
    19  MyApp             0x0000000100001654 start + 52
)
4

2 に答える 2

0

http://hints.macworld.com/index.php?topic=system107&page=5

これは、OS X 10.7.* (Lion) シリーズのバグのようです。コードをまったく変更しないと、Xcode 4.4.1 に準拠した OS X 10.8 (Mountain Lion) でクラッシュが発生しなくなりました。

于 2014-01-18T17:32:40.650 に答える