Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

version 1.16.0 : Fatal Exception: NSRangeException Cannot remove an observer <KeyboardMovementObserver 0x301d09cc0> for the key path "center" from <UIInputSetHostView 0x157fd7b10> because it is not registered as an observer. #802

Closed
ethanneff opened this issue Feb 8, 2025 · 10 comments
Assignees
Labels
🎯 crash Library triggers a crash of the app 🍎 iOS iOS specific

Comments

@ethanneff
Copy link

Describe the bug

Getting lots of crashes on iOS devices

 Fatal Exception: NSRangeException
0  CoreFoundation                 0x83f20 __exceptionPreprocess
1  libobjc.A.dylib                0x172b8 objc_exception_throw
2  Foundation                     0x13cdb0 -[NSObject(NSKeyValueObserverRegistration) _removeObserver:forProperty:]
3  Foundation                     0x13caf0 -[NSObject(NSKeyValueObserverRegistration) removeObserver:forKeyPath:]
4  Foundation                     0x13ca08 -[NSObject(NSKeyValueObserverRegistration) removeObserver:forKeyPath:context:]
5  App                            0x93d0f8 KeyboardMovementObserver.keyboardWillDisappear(_:) + 112 (KeyboardMovementObserver.swift:112)
6  App                            0x93db38 @objc KeyboardMovementObserver.keyboardWillAppear(_:)
7  CoreFoundation                 0x5178c __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__
8  CoreFoundation                 0x516a8 ___CFXRegistrationPost_block_invoke
9  CoreFoundation                 0x515f0 _CFXRegistrationPost
10 CoreFoundation                 0x4fbb8 _CFXNotificationPost
11 Foundation                     0x31254 -[NSNotificationCenter postNotificationName:object:userInfo:]
12 UIKitCore                      0x3ed44c -[UIInputWindowController postNotificationName:userInfo:]
13 UIKitCore                      0x3ecec4 __68-[UIInputWindowController postValidatedStartNotifications:withInfo:]_block_invoke
14 UIKitCore                      0x328684 -[UIInputWindowController postValidatedStartNotifications:withInfo:]
15 UIKitCore                      0x3283d0 -[UIInputWindowController postStartNotifications:withInfo:]
16 UIKitCore                      0x1724ec __77-[UIInputWindowController moveFromPlacement:toPlacement:starting:completion:]_block_invoke.510
17 UIKitCore                      0x3eb9a8 -[UIInputViewAnimationStyle launchAnimation:afterStarted:completion:forHost:fromCurrentPosition:]
18 UIKitCore                      0x3eb814 __77-[UIInputWindowController moveFromPlacement:toPlacement:starting:completion:]_block_invoke.538
19 UIKitCore                      0x3eb1c0 -[UIInputWindowController chainPlacementsIfNecessaryFrom:toPlacement:transition:completion:]
20 UIKitCore                      0x218a2c -[UIInputWindowController moveFromPlacement:toPlacement:starting:completion:]
21 UIKitCore                      0x325320 -[UIInputWindowController setInputViewSet:]
22 UIKitCore                      0x324c78 -[UIInputWindowController performOperations:withAnimationStyle:]
23 UIKitCore                      0x16e0b0 -[UIKeyboardSceneDelegate setKeyWindowSceneInputViews:animationStyle:]
24 UIKitCore                      0x325cb0 -[UIKeyboardSceneDelegate setInputViews:animationStyle:]
25 UIKitCore                      0x325bfc -[UIKeyboardSceneDelegate setInputViews:animated:]
26 UIKitCore                      0x325b8c -[UIKeyboardSceneDelegate setInputViews:]
27 UIKitCore                      0x2c74ac __102-[UIKeyboardSceneDelegate _reloadInputViewsForKeyWindowSceneResponder:force:fromBecomeFirstResponder:]_block_invoke.502
28 UIKitCore                      0x2c5a58 -[UIKeyboardSceneDelegate _reloadInputViewsForKeyWindowSceneResponder:force:fromBecomeFirstResponder:]
29 UIKitCore                      0x325e08 -[UIKeyboardSceneDelegate _reloadInputViewsForResponder:force:fromBecomeFirstResponder:]
30 UIKitCore                      0x364e58 -[UIResponder _finishResignFirstResponderFromBecomeFirstResponder:]
31 UIKitCore                      0x3643a8 -[UIResponder resignFirstResponder]
32 App                            0x942120 closure #1 in static UIResponder.swizzleResignFirstResponder() + 47 (UIResponderSwizzle.swift:47)
33 App                            0x942240 thunk for @escaping @callee_guaranteed (@guaranteed UIResponder) -> (@unowned Bool) (<compiler-generated>)
34 UIKitCore                      0x3624cc -[UITextField resignFirstResponder]
35 UIKitCore                      0xe0c80 __UIViewWillBeRemovedFromSuperview
36 UIKitCore                      0xe07b4 -[UIView(Hierarchy) removeFromSuperview]
37 App                            0x42f874 -[RCTViewComponentView unmountChildComponentView:index:] + 166 (RCTViewComponentView.mm:166)
38 App                            0x3fddf4 std::__1::__function::__func<-[RCTMountingManager performTransaction:]::$_1, std::__1::allocator<-[RCTMountingManager performTransaction:]::$_1>, void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)>::operator()(facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&) + 101 (RCTMountingManager.mm:101)
39 App                            0x6d2520 facebook::react::TelemetryController::pullTransaction(std::__1::function<void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)> const&, std::__1::function<void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)> const&, std::__1::function<void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)> const&) const + 40 (TelemetryController.cpp:40)
40 App                            0x3fcb7c -[RCTMountingManager performTransaction:] + 476 (function.h:476)
41 App                            0x3fca98 -[RCTMountingManager initiateTransaction:] + 251 (RCTMountingManager.mm:251)
42 App                            0x4196d4 -[RCTSurfacePresenter schedulerShouldRenderTransactions:] + 772 (shared_ptr.h:772)
43 App                            0x40e834 SchedulerDelegateProxy::schedulerShouldRenderTransactions(std::__1::shared_ptr<facebook::react::MountingCoordinator const> const&) + 772 (shared_ptr.h:772)
44 App                            0x6c6790 facebook::react::Scheduler::uiManagerDidFinishTransaction(std::__1::shared_ptr<facebook::react::MountingCoordinator const>, bool) + 772 (shared_ptr.h:772)
45 App                            0x6d8234 facebook::react::UIManager::shadowTreeDidFinishTransaction(std::__1::shared_ptr<facebook::react::MountingCoordinator const>, bool) const + 772 (shared_ptr.h:772)
46 App                            0x6ca81c facebook::react::ShadowTree::mount(facebook::react::ShadowTreeRevision, bool) const + 772 (shared_ptr.h:772)
47 App                            0x6cb134 facebook::react::ShadowTree::tryCommit(std::__1::function<std::__1::shared_ptr<facebook::react::RootShadowNode> (facebook::react::RootShadowNode const&)> const&, facebook::react::ShadowTree::CommitOptions const&) const + 476 (function.h:476)
48 App                            0x6ca910 facebook::react::ShadowTree::commit(std::__1::function<std::__1::shared_ptr<facebook::react::RootShadowNode> (facebook::react::RootShadowNode const&)> const&, facebook::react::ShadowTree::CommitOptions const&) const + 357 (ShadowTree.cpp:357)
49 App                            0x6cbba8 facebook::react::ShadowTree::commitEmptyTree() const + 476 (function.h:476)
50 App                            0x6cf9d4 facebook::react::SurfaceHandler::stop() const + 68 (unique_ptr.h:68)
51 App                            0x3f05d4 -[RCTFabricSurface stop] + 122 (RCTFabricSurface.mm:122)
52 App                            0x4195e4 __53-[RCTSurfacePresenter _stopAllSurfacesWithScheduler:]_block_invoke + 292 (RCTSurfacePresenter.mm:292)
53 App                            0x41dbc0 -[RCTSurfaceRegistry enumerateWithBlock:] + 35 (RCTSurfaceRegistry.mm:35)
54 App                            0x419510 -[RCTSurfacePresenter _stopAllSurfacesWithScheduler:] + 295 (RCTSurfacePresenter.mm:295)
55 App                            0x418678 -[RCTSurfacePresenter suspend] + 197 (RCTSurfacePresenter.mm:197)
56 CoreFoundation                 0x5178c __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__
57 CoreFoundation                 0x516a8 ___CFXRegistrationPost_block_invoke
58 CoreFoundation                 0x515f0 _CFXRegistrationPost
59 CoreFoundation                 0x4fbb8 _CFXNotificationPost
60 Foundation                     0x31254 -[NSNotificationCenter postNotificationName:object:userInfo:]
61 UIKitCore                      0xec5154 -[UIApplication _terminateWithStatus:]
62 UIKitCore                      0x19a170 -[_UISceneLifecycleMultiplexer _evalTransitionToSettings:fromSettings:forceExit:withTransitionStore:]
63 UIKitCore                      0x7a9be4 -[_UISceneLifecycleMultiplexer forceExitWithTransitionContext:scene:]
64 UIKitCore                      0xec081c -[UIApplication workspaceShouldExit:withTransitionContext:]
65 FrontBoardServices             0x4e3e8 __63-[FBSWorkspaceScenesClient willTerminateWithTransitionContext:]_block_invoke_2
66 FrontBoardServices             0x166cc -[FBSWorkspace _calloutQueue_executeCalloutFromSource:withBlock:]
67 FrontBoardServices             0x4e388 __63-[FBSWorkspaceScenesClient willTerminateWithTransitionContext:]_block_invoke
68 libdispatch.dylib              0x3dd4 _dispatch_client_callout
69 libdispatch.dylib              0x786c _dispatch_block_invoke_direct
70 FrontBoardServices             0x17d58 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__
71 FrontBoardServices             0x17cd8 -[FBSMainRunLoopSerialQueue _targetQueue_performNextIfPossible]
72 FrontBoardServices             0x17bb0 -[FBSMainRunLoopSerialQueue _performNextFromRunLoopSource]
73 CoreFoundation                 0x56834 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__
74 CoreFoundation                 0x567c8 __CFRunLoopDoSource0
75 CoreFoundation                 0x542f8 __CFRunLoopDoSources0
76 CoreFoundation                 0x53484 __CFRunLoopRun
77 CoreFoundation                 0x52cd8 CFRunLoopRunSpecific
78 GraphicsServices               0x11a8 GSEventRunModal
79 UIKitCore                      0x40aae8 -[UIApplication _run]
80 UIKitCore                      0x4bed98 UIApplicationMain
81 App                            0x82f8 main + 8 (main.m:8)
82 ???                            0x1b94f7154 (Missing)
  • RN version: 0.75.5
  • RN architecture: new
  • JS engine: hermes
  • Library version: 1.16.2
@kirillzyusko
Copy link
Owner

kirillzyusko commented Feb 8, 2025

@ethanneff are you sure that crash comes from the latest (1.16.2) keyboard-controller version?

It points to 112 line, but this line in 1.16.2 is a simple if condition:

In 1.16.0 and potentially earlier versions it was pointing out to _removeObserver function:

_keyboardView?.removeObserver(self, forKeyPath: "center", context: nil)

@kirillzyusko kirillzyusko added the 🎯 crash Library triggers a crash of the app label Feb 8, 2025
@kirillzyusko
Copy link
Owner

@ethanneff and can you give more information? Did you use the lib before and you had a small amount of crashes, then started to use 1.16 and the amount of crashes has been increased?

If you updated the lib, then which potential versions can be used in production?

@kirillzyusko kirillzyusko added the 🍎 iOS iOS specific label Feb 8, 2025
@ethanneff
Copy link
Author

ethanneff commented Feb 12, 2025

Sorry, I was looking into it as well - but could not reproduce it. We are still getting some crashes on iOS devices.

Image

We are using "react-native-keyboard-controller": "1.16.2" with "react-native": "0.76.5",

Below is another stack trace:

# Crashlytics - Stack trace
# Platform: apple
# Version: 2.50206.22 (1738910990)
# Issue: a3b576056fa54b55869c9553030acdd3
# Session: a2d380beb92c47fab848b09e8be8e4e3_DNE_0_v2
# Date: Tue Feb 11 2025 21:28:18 GMT-0800 (Pacific Standard Time)

Fatal Exception: NSRangeException
0  CoreFoundation                 0x2d5fc __exceptionPreprocess
1  libobjc.A.dylib                0x31244 objc_exception_throw
2  Foundation                     0x1cf2e0 -[NSObject(NSKeyValueObserverRegistration) _removeObserver:forProperty:]
3  Foundation                     0x1cf020 -[NSObject(NSKeyValueObserverRegistration) removeObserver:forKeyPath:]
4  Foundation                     0x1cef38 -[NSObject(NSKeyValueObserverRegistration) removeObserver:forKeyPath:context:]
5  App                            0x93d0f8 KeyboardMovementObserver.keyboardWillDisappear(_:) + 112 (KeyboardMovementObserver.swift:112)
6  App                            0x93db38 @objc KeyboardMovementObserver.keyboardWillAppear(_:)
7  CoreFoundation                 0x4e488 __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__
8  CoreFoundation                 0x4e3a4 ___CFXRegistrationPost_block_invoke
9  CoreFoundation                 0x4cf18 _CFXRegistrationPost
10 CoreFoundation                 0x4c01c _CFXNotificationPost
11 Foundation                     0x9fa9c -[NSNotificationCenter postNotificationName:object:userInfo:]
12 UIKitCore                      0xf27c04 -[UIInputWindowController postNotificationName:userInfo:]
13 UIKitCore                      0xf28434 __68-[UIInputWindowController postValidatedStartNotifications:withInfo:]_block_invoke
14 UIKitCore                      0xf27f0c -[UIInputWindowController postValidatedStartNotifications:withInfo:]
15 UIKitCore                      0xf27e04 -[UIInputWindowController postStartNotifications:withInfo:]
16 UIKitCore                      0xf2d4b0 __77-[UIInputWindowController moveFromPlacement:toPlacement:starting:completion:]_block_invoke.529
17 UIKitCore                      0xcd647c -[UIInputViewAnimationStyle launchAnimation:afterStarted:completion:forHost:fromCurrentPosition:]
18 UIKitCore                      0xf2e9c8 __77-[UIInputWindowController moveFromPlacement:toPlacement:starting:completion:]_block_invoke.557
19 UIKitCore                      0xf2ee88 -[UIInputWindowController chainPlacementsIfNecessaryFrom:toPlacement:transition:completion:]
20 UIKitCore                      0xf2cdf8 -[UIInputWindowController moveFromPlacement:toPlacement:starting:completion:]
21 UIKitCore                      0x418c00 -[UIInputWindowController setInputViewSet:]
22 UIKitCore                      0xaf0d8 -[UIInputWindowController performOperations:withAnimationStyle:]
23 UIKitCore                      0x1e13e8 -[UIKeyboardSceneDelegate setKeyWindowSceneInputViews:animationStyle:]
24 UIKitCore                      0x418558 -[UIKeyboardSceneDelegate setInputViews:animationStyle:]
25 UIKitCore                      0x418378 -[UIKeyboardSceneDelegate setInputViews:animated:]
26 UIKitCore                      0x418308 -[UIKeyboardSceneDelegate setInputViews:]
27 UIKitCore                      0xbd7830 __102-[UIKeyboardSceneDelegate _reloadInputViewsForKeyWindowSceneResponder:force:fromBecomeFirstResponder:]_block_invoke.567
28 UIKitCore                      0x1e3e04 -[UIKeyboardSceneDelegate _reloadInputViewsForKeyWindowSceneResponder:force:fromBecomeFirstResponder:]
29 UIKitCore                      0x4190dc -[UIKeyboardSceneDelegate _reloadInputViewsForResponder:force:fromBecomeFirstResponder:]
30 UIKitCore                      0xb0018 -[UIResponder _finishResignFirstResponderFromBecomeFirstResponder:]
31 UIKitCore                      0xaea9c -[UIResponder resignFirstResponder]
32 App                            0x942120 closure #1 in static UIResponder.swizzleResignFirstResponder() + 47 (UIResponderSwizzle.swift:47)
33 App                            0x942240 thunk for @escaping @callee_guaranteed (@guaranteed UIResponder) -> (@unowned Bool) (<compiler-generated>)
34 UIKitCore                      0x1422f88 -[UITextField resignFirstResponder]
35 UIKitCore                      0x98e88 __UIViewWillBeRemovedFromSuperview
36 UIKitCore                      0x98a70 -[UIView(Hierarchy) removeFromSuperview]
37 App                            0x42f874 -[RCTViewComponentView unmountChildComponentView:index:] + 166 (RCTViewComponentView.mm:166)
38 App                            0x3fddf4 std::__1::__function::__func<-[RCTMountingManager performTransaction:]::$_1, std::__1::allocator<-[RCTMountingManager performTransaction:]::$_1>, void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)>::operator()(facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&) + 101 (RCTMountingManager.mm:101)
39 App                            0x6d2520 facebook::react::TelemetryController::pullTransaction(std::__1::function<void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)> const&, std::__1::function<void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)> const&, std::__1::function<void (facebook::react::MountingTransaction const&, facebook::react::SurfaceTelemetry const&)> const&) const + 40 (TelemetryController.cpp:40)
40 App                            0x3fcb7c -[RCTMountingManager performTransaction:] + 476 (function.h:476)
41 App                            0x3fca98 -[RCTMountingManager initiateTransaction:] + 251 (RCTMountingManager.mm:251)
42 App                            0x4196d4 -[RCTSurfacePresenter schedulerShouldRenderTransactions:] + 772 (shared_ptr.h:772)
43 App                            0x40e834 SchedulerDelegateProxy::schedulerShouldRenderTransactions(std::__1::shared_ptr<facebook::react::MountingCoordinator const> const&) + 772 (shared_ptr.h:772)
44 App                            0x6c6790 facebook::react::Scheduler::uiManagerDidFinishTransaction(std::__1::shared_ptr<facebook::react::MountingCoordinator const>, bool) + 772 (shared_ptr.h:772)
45 App                            0x6d8234 facebook::react::UIManager::shadowTreeDidFinishTransaction(std::__1::shared_ptr<facebook::react::MountingCoordinator const>, bool) const + 772 (shared_ptr.h:772)
46 App                            0x6ca81c facebook::react::ShadowTree::mount(facebook::react::ShadowTreeRevision, bool) const + 772 (shared_ptr.h:772)
47 App                            0x6cb134 facebook::react::ShadowTree::tryCommit(std::__1::function<std::__1::shared_ptr<facebook::react::RootShadowNode> (facebook::react::RootShadowNode const&)> const&, facebook::react::ShadowTree::CommitOptions const&) const + 476 (function.h:476)
48 App                            0x6ca910 facebook::react::ShadowTree::commit(std::__1::function<std::__1::shared_ptr<facebook::react::RootShadowNode> (facebook::react::RootShadowNode const&)> const&, facebook::react::ShadowTree::CommitOptions const&) const + 357 (ShadowTree.cpp:357)
49 App                            0x6cbba8 facebook::react::ShadowTree::commitEmptyTree() const + 476 (function.h:476)
50 App                            0x6cf9d4 facebook::react::SurfaceHandler::stop() const + 68 (unique_ptr.h:68)
51 App                            0x3f05d4 -[RCTFabricSurface stop] + 122 (RCTFabricSurface.mm:122)
52 App                            0x4195e4 __53-[RCTSurfacePresenter _stopAllSurfacesWithScheduler:]_block_invoke + 292 (RCTSurfacePresenter.mm:292)
53 App                            0x41dbc0 -[RCTSurfaceRegistry enumerateWithBlock:] + 35 (RCTSurfaceRegistry.mm:35)
54 App                            0x419510 -[RCTSurfacePresenter _stopAllSurfacesWithScheduler:] + 295 (RCTSurfacePresenter.mm:295)
55 App                            0x418678 -[RCTSurfacePresenter suspend] + 197 (RCTSurfacePresenter.mm:197)
56 CoreFoundation                 0x4e488 __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__
57 CoreFoundation                 0x4e3a4 ___CFXRegistrationPost_block_invoke
58 CoreFoundation                 0x4cf18 _CFXRegistrationPost
59 CoreFoundation                 0x4c01c _CFXNotificationPost
60 Foundation                     0x9fa9c -[NSNotificationCenter postNotificationName:object:userInfo:]
61 UIKitCore                      0x115c528 -[UIApplication _terminateWithStatus:]
62 UIKitCore                      0x1b5644 -[_UISceneLifecycleMultiplexer _evalTransitionToSettings:fromSettings:forceExit:withTransitionStore:]
63 UIKitCore                      0x906e8c -[_UISceneLifecycleMultiplexer forceExitWithTransitionContext:scene:]
64 UIKitCore                      0x1157c28 -[UIApplication workspaceShouldExit:withTransitionContext:]
65 FrontBoardServices             0x56cd4 __63-[FBSWorkspaceScenesClient willTerminateWithTransitionContext:]_block_invoke_2
66 FrontBoardServices             0x1f4c8 -[FBSWorkspace _calloutQueue_executeCalloutFromSource:withBlock:]
67 FrontBoardServices             0x56c74 __63-[FBSWorkspaceScenesClient willTerminateWithTransitionContext:]_block_invoke
68 libdispatch.dylib              0x3fa8 _dispatch_client_callout
69 libdispatch.dylib              0x79f0 _dispatch_block_invoke_direct
70 FrontBoardServices             0x18378 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__
71 FrontBoardServices             0x182f8 -[FBSMainRunLoopSerialQueue _targetQueue_performNextIfPossible]
72 FrontBoardServices             0x181d0 -[FBSMainRunLoopSerialQueue _performNextFromRunLoopSource]
73 CoreFoundation                 0x73f4c __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__
74 CoreFoundation                 0x73ee0 __CFRunLoopDoSource0
75 CoreFoundation                 0x76ba4 __CFRunLoopDoSources0
76 CoreFoundation                 0x75d3c __CFRunLoopRun
77 CoreFoundation                 0xc8284 CFRunLoopRunSpecific
78 GraphicsServices               0x14c0 GSEventRunModal
79 UIKitCore                      0x3ee674 -[UIApplication _run]
80 UIKitCore                      0x14e88 UIApplicationMain
81 App                            0x82f8 main + 8 (main.m:8)
82 ???                            0x1c304dde8 (Missing)

Crashed: com.google.firebase.crashlytics.ios.exception
0  App                            0xa5538 FIRCLSProcessRecordAllThreads + 392 (FIRCLSProcess.c:392)
1  App                            0xa5918 FIRCLSProcessRecordAllThreads + 423 (FIRCLSProcess.c:423)
2  App                            0x9d688 FIRCLSHandler + 34 (FIRCLSHandler.m:34)
3  App                            0x985e8 __FIRCLSExceptionRecord_block_invoke + 240 (FIRCLSException.mm:240)
4  libdispatch.dylib              0x3fa8 _dispatch_client_callout + 20
5  libdispatch.dylib              0x137fc _dispatch_lane_barrier_sync_invoke_and_complete + 56
6  App                            0x97590 FIRCLSExceptionRecord + 242 (FIRCLSException.mm:242)
7  App                            0x980ac FIRCLSExceptionRecordNSException + 126 (FIRCLSException.mm:126)
8  App                            0x97198 FIRCLSTerminateHandler() + 407 (FIRCLSException.mm:407)
9  App                            0x7c536c CPPExceptionTerminate() + 128 (SentryCrashMonitor_CPPException.cpp:128)
10 libc++abi.dylib                0x1287c std::__terminate(void (*)()) + 16
11 libc++abi.dylib                0x12820 std::terminate() + 108
12 App                            0x4d64c std::__1::unordered_map<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, objc_class* (*)(), std::__1::hash<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, std::__1::equal_to<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>, std::__1::allocator<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, objc_class* (*)()>>>::unordered_map(std::initializer_list<std::__1::pair<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const, objc_class* (*)()>>) + 1839 (unordered_map:1839)
13 App                            0x6cf9f4 facebook::react::SurfaceHandler::setDisplayMode(facebook::react::DisplayMode) const + 116 (SurfaceHandler.cpp:116)
14 App                            0x3f05d4 -[RCTFabricSurface stop] + 122 (RCTFabricSurface.mm:122)
15 App                            0x4195e4 __53-[RCTSurfacePresenter _stopAllSurfacesWithScheduler:]_block_invoke + 292 (RCTSurfacePresenter.mm:292)
16 App                            0x41dbc0 -[RCTSurfaceRegistry enumerateWithBlock:] + 35 (RCTSurfaceRegistry.mm:35)
17 App                            0x419510 -[RCTSurfacePresenter _stopAllSurfacesWithScheduler:] + 295 (RCTSurfacePresenter.mm:295)
18 App                            0x418678 -[RCTSurfacePresenter suspend] + 197 (RCTSurfacePresenter.mm:197)
19 CoreFoundation                 0x4e488 __CFNOTIFICATIONCENTER_IS_CALLING_OUT_TO_AN_OBSERVER__ + 148
20 CoreFoundation                 0x4e3a4 ___CFXRegistrationPost_block_invoke + 88
21 CoreFoundation                 0x4cf18 _CFXRegistrationPost + 436
22 CoreFoundation                 0x4c01c _CFXNotificationPost + 728
23 Foundation                     0x9fa9c -[NSNotificationCenter postNotificationName:object:userInfo:] + 92
24 UIKitCore                      0x115c528 -[UIApplication _terminateWithStatus:] + 232
25 UIKitCore                      0x1b5644 -[_UISceneLifecycleMultiplexer _evalTransitionToSettings:fromSettings:forceExit:withTransitionStore:] + 112
26 UIKitCore                      0x906e8c -[_UISceneLifecycleMultiplexer forceExitWithTransitionContext:scene:] + 164
27 UIKitCore                      0x1157c28 -[UIApplication workspaceShouldExit:withTransitionContext:] + 164
28 FrontBoardServices             0x56cd4 __63-[FBSWorkspaceScenesClient willTerminateWithTransitionContext:]_block_invoke_2 + 72
29 FrontBoardServices             0x1f4c8 -[FBSWorkspace _calloutQueue_executeCalloutFromSource:withBlock:] + 168
30 FrontBoardServices             0x56c74 __63-[FBSWorkspaceScenesClient willTerminateWithTransitionContext:]_block_invoke + 128
31 libdispatch.dylib              0x3fa8 _dispatch_client_callout + 20
32 libdispatch.dylib              0x79f0 _dispatch_block_invoke_direct + 284
33 FrontBoardServices             0x18378 __FBSSERIALQUEUE_IS_CALLING_OUT_TO_A_BLOCK__ + 52
34 FrontBoardServices             0x182f8 -[FBSMainRunLoopSerialQueue _targetQueue_performNextIfPossible] + 240
35 FrontBoardServices             0x181d0 -[FBSMainRunLoopSerialQueue _performNextFromRunLoopSource] + 28
36 CoreFoundation                 0x73f4c __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 28
37 CoreFoundation                 0x73ee0 __CFRunLoopDoSource0 + 176
38 CoreFoundation                 0x76ba4 __CFRunLoopDoSources0 + 344
39 CoreFoundation                 0x75d3c __CFRunLoopRun + 840
40 CoreFoundation                 0xc8284 CFRunLoopRunSpecific + 588
41 GraphicsServices               0x14c0 GSEventRunModal + 164
42 UIKitCore                      0x3ee674 -[UIApplication _run] + 816
43 UIKitCore                      0x14e88 UIApplicationMain + 340
44 App                            0x82f8 main + 8 (main.m:8)
45 ???                            0x1c304dde8 (Missing)

com.apple.uikit.eventfetch-thread
0  libsystem_kernel.dylib         0x1788 mach_msg2_trap + 8
1  libsystem_kernel.dylib         0x4e98 mach_msg2_internal + 80
2  libsystem_kernel.dylib         0x4db0 mach_msg_overwrite + 424
3  libsystem_kernel.dylib         0x4bfc mach_msg + 24
4  CoreFoundation                 0x76804 __CFRunLoopServiceMachPort + 160
5  CoreFoundation                 0x75eb0 __CFRunLoopRun + 1212
6  CoreFoundation                 0xc8284 CFRunLoopRunSpecific + 588
7  Foundation                     0x2a0e8 -[NSRunLoop(NSRunLoop) runMode:beforeDate:] + 212
8  Foundation                     0x186bb0 -[NSRunLoop(NSRunLoop) runUntilDate:] + 64
9  UIKitCore                      0x481a78 -[UIEventFetcher threadMain] + 420
10 Foundation                     0x115f30 __NSThread__start__ + 724
11 libsystem_pthread.dylib        0x17d0 _pthread_start + 136
12 libsystem_pthread.dylib        0x1480 thread_start + 8

com.google.firebase.crashlytics.MachExceptionServer
0  libsystem_kernel.dylib         0x1788 mach_msg2_trap + 8
1  libsystem_kernel.dylib         0x4e98 mach_msg2_internal + 80
2  libsystem_kernel.dylib         0x4db0 mach_msg_overwrite + 424
3  libsystem_kernel.dylib         0x4bfc mach_msg + 24
4  App                            0x9fdb4 FIRCLSMachExceptionServer + 196 (FIRCLSMachException.c:196)
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

com.facebook.react.runtime.JavaScript
0  libsystem_kernel.dylib         0x1788 mach_msg2_trap + 8
1  libsystem_kernel.dylib         0x4e98 mach_msg2_internal + 80
2  libsystem_kernel.dylib         0x4db0 mach_msg_overwrite + 424
3  libsystem_kernel.dylib         0x4bfc mach_msg + 24
4  CoreFoundation                 0x76804 __CFRunLoopServiceMachPort + 160
5  CoreFoundation                 0x75eb0 __CFRunLoopRun + 1212
6  CoreFoundation                 0xc8284 CFRunLoopRunSpecific + 588
7  App                            0x73e648 +[RCTJSThreadManager runRunLoop] + 102 (RCTJSThreadManager.mm:102)
8  Foundation                     0x115f30 __NSThread__start__ + 724
9  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
10 libsystem_pthread.dylib        0x1480 thread_start + 8

hades
0  libsystem_kernel.dylib         0x7090 __psynch_cvwait + 8
1  libsystem_pthread.dylib        0x3f98 _pthread_cond_wait + 1204
2  libc++.1.dylib                 0x21584 std::__1::condition_variable::wait(std::__1::unique_lock<std::__1::mutex>&) + 28
3  hermes                         0xccdf8 hermes::vm::HadesGC::Executor::worker() + 116
4  hermes                         0xccd60 void* std::__1::__thread_proxy[abi:v160006]<std::__1::tuple<std::__1::unique_ptr<std::__1::__thread_struct, std::__1::default_delete<std::__1::__thread_struct>>, hermes::vm::HadesGC::Executor::Executor()::'lambda'()>>(void*) + 44
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

com.apple.NSURLConnectionLoader
0  libsystem_kernel.dylib         0x1788 mach_msg2_trap + 8
1  libsystem_kernel.dylib         0x4e98 mach_msg2_internal + 80
2  libsystem_kernel.dylib         0x4db0 mach_msg_overwrite + 424
3  libsystem_kernel.dylib         0x4bfc mach_msg + 24
4  CoreFoundation                 0x76804 __CFRunLoopServiceMachPort + 160
5  CoreFoundation                 0x75eb0 __CFRunLoopRun + 1212
6  CoreFoundation                 0xc8284 CFRunLoopRunSpecific + 588
7  CFNetwork                      0xf1c4c +[__CFN_CoreSchedulingSetRunnable _run:] + 416
8  Foundation                     0x115f30 __NSThread__start__ + 724
9  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
10 libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x72b0 __semwait_signal + 8
1  libsystem_c.dylib              0x185cc nanosleep + 220
2  libsystem_c.dylib              0x18444 sleep + 52
3  App                            0x7bb0e0 monitorCachedData + 146 (SentryCrashCachedData.c:146)
4  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
5  libsystem_pthread.dylib        0x1480 thread_start + 8

SentryCrash Exception Handler (Secondary)
0  libsystem_kernel.dylib         0x1788 mach_msg2_trap + 8
1  libsystem_kernel.dylib         0x4e98 mach_msg2_internal + 80
2  libsystem_kernel.dylib         0x2cfc thread_suspend + 108
3  App                            0x7c5a14 handleExceptions + 305 (SentryCrashMonitor_MachException.c:305)
4  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
5  libsystem_pthread.dylib        0x1480 thread_start + 8

SentryCrash Exception Handler (Primary)
0  libsystem_kernel.dylib         0x1788 mach_msg2_trap + 8
1  libsystem_kernel.dylib         0x4e98 mach_msg2_internal + 80
2  libsystem_kernel.dylib         0x4db0 mach_msg_overwrite + 424
3  libsystem_kernel.dylib         0x4bfc mach_msg + 24
4  App                            0x7c5a40 handleExceptions + 315 (SentryCrashMonitor_MachException.c:315)
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

io.sentry.app-hang-tracker
0  libsystem_kernel.dylib         0x72b0 __semwait_signal + 8
1  libsystem_c.dylib              0x185cc nanosleep + 220
2  Foundation                     0x8ac2a8 +[NSThread sleepForTimeInterval:] + 160
3  App                            0x7a5cd4 -[SentryANRTrackerV1 detectANRs] + 105 (SentryANRTrackerV1.m:105)
4  Foundation                     0x115f30 __NSThread__start__ + 724
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

futures-timer
0  libsystem_kernel.dylib         0x171c semaphore_timedwait_trap + 8
1  libdispatch.dylib              0x45c0 _dispatch_sema4_timedwait + 64
2  libdispatch.dylib              0x4bc0 _dispatch_semaphore_wait_slow + 76
3  FullStory                      0x9ed08 rust_eh_personality + 10524
4  FullStory                      0x2ee10 __fs_log_impl + 62044
5  FullStory                      0xa21d0 rust_eh_personality + 24036
6  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
7  libsystem_pthread.dylib        0x1480 thread_start + 8

hades
0  libsystem_kernel.dylib         0x7090 __psynch_cvwait + 8
1  libsystem_pthread.dylib        0x3f98 _pthread_cond_wait + 1204
2  libc++.1.dylib                 0x21584 std::__1::condition_variable::wait(std::__1::unique_lock<std::__1::mutex>&) + 28
3  hermes                         0xccdf8 hermes::vm::HadesGC::Executor::worker() + 116
4  hermes                         0xccd60 void* std::__1::__thread_proxy[abi:v160006]<std::__1::tuple<std::__1::unique_ptr<std::__1::__thread_struct, std::__1::default_delete<std::__1::__thread_struct>>, hermes::vm::HadesGC::Executor::Executor()::'lambda'()>>(void*) + 44
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  UIKitCore                      0x509964 UICollectionViewFlowLayoutBreakForInvalidSizes + 26052
4  UIKitCore                      0x2f959c -[_UIAppCACommitFuture _invoke] + 176
5  Foundation                     0x115f30 __NSThread__start__ + 724
6  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
7  libsystem_pthread.dylib        0x1480 thread_start + 8

JavaScriptCore libpas scavenger
0  libsystem_kernel.dylib         0x7090 __psynch_cvwait + 8
1  libsystem_pthread.dylib        0x3f98 _pthread_cond_wait + 1204
2  JavaScriptCore                 0xfc620 scavenger_thread_main + 1328
3  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
4  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-0
0  libsystem_kernel.dylib         0x7b78 __psynch_mutexwait + 8
1  libsystem_pthread.dylib        0x48a0 _pthread_mutex_firstfit_lock_wait + 84
2  libsystem_pthread.dylib        0x4250 _pthread_mutex_firstfit_lock_slow + 220
3  FullStory                      0x2cdbc __fs_log_impl + 53768
4  FullStory                      0xa21d0 rust_eh_personality + 24036
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-1
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x2bdf4 __fs_log_impl + 49728
5  FullStory                      0x2c990 __fs_log_impl + 52700
6  FullStory                      0x2ce9c __fs_log_impl + 53992
7  FullStory                      0xa21d0 rust_eh_personality + 24036
8  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
9  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-2
0  libsystem_kernel.dylib         0x7b78 __psynch_mutexwait + 8
1  libsystem_pthread.dylib        0x48a0 _pthread_mutex_firstfit_lock_wait + 84
2  libsystem_pthread.dylib        0x4250 _pthread_mutex_firstfit_lock_slow + 220
3  FullStory                      0x2cdbc __fs_log_impl + 53768
4  FullStory                      0xa21d0 rust_eh_personality + 24036
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-3
0  libsystem_kernel.dylib         0x7b78 __psynch_mutexwait + 8
1  libsystem_pthread.dylib        0x48a0 _pthread_mutex_firstfit_lock_wait + 84
2  libsystem_pthread.dylib        0x4250 _pthread_mutex_firstfit_lock_slow + 220
3  FullStory                      0x2cdbc __fs_log_impl + 53768
4  FullStory                      0xa21d0 rust_eh_personality + 24036
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

com.fullstory.thunk_queue_very_much
0  libsystem_kernel.dylib         0x7bd0 __ulock_wait + 8
1  libdispatch.dylib              0x4998 _dlock_wait + 56
2  libdispatch.dylib              0x474c _dispatch_thread_event_wait_slow + 56
3  libdispatch.dylib              0x13ae8 __DISPATCH_WAIT_FOR_QUEUE__ + 368
4  libdispatch.dylib              0x13694 _dispatch_sync_f_slow + 148
5  FullStory                      0xdf7b8 PopulateInclusiveFramesForLayer(id<FSShared>, CALayer*) + 10148
6  FullStory                      0xda360 bcmap_addDelta(std::__1::vector<unsigned short, std::__1::allocator<unsigned short>>&, long long) + 57636
7  FullStory                      0xedc5c FSGetDeviceModel + 27424
8  FullStory                      0xdc210 bcmap_addDelta(std::__1::vector<unsigned short, std::__1::allocator<unsigned short>>&, long long) + 65492
9  FullStory                      0xdc550 bcmap_addDelta(std::__1::vector<unsigned short, std::__1::allocator<unsigned short>>&, long long) + 66324
10 libdispatch.dylib              0x2248 _dispatch_call_block_and_release + 32
11 libdispatch.dylib              0x3fa8 _dispatch_client_callout + 20
12 libdispatch.dylib              0xb5cc _dispatch_lane_serial_drain + 768
13 libdispatch.dylib              0xc124 _dispatch_lane_invoke + 380
14 libdispatch.dylib              0x1738c _dispatch_root_queue_drain_deferred_wlh + 288
15 libdispatch.dylib              0x16bd8 _dispatch_workloop_worker_thread + 540
16 libsystem_pthread.dylib        0x3680 _pthread_wqthread + 288
17 libsystem_pthread.dylib        0x1474 start_wqthread + 8

AudioSession - RootQueue
0  libsystem_kernel.dylib         0x171c semaphore_timedwait_trap + 8
1  libdispatch.dylib              0x45c0 _dispatch_sema4_timedwait + 64
2  libdispatch.dylib              0x4bc0 _dispatch_semaphore_wait_slow + 76
3  libdispatch.dylib              0x15c94 _dispatch_worker_thread + 324
4  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
5  libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x281b0 __fs_log_impl + 34300
5  FullStory                      0x4de84 __fs_log_impl + 189136
6  FullStory                      0x4a2fc __fs_log_impl + 173896
7  FullStory                      0x49354 __fs_log_impl + 169888
8  FullStory                      0xa21d0 rust_eh_personality + 24036
9  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
10 libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-0
0  libsystem_kernel.dylib         0x7090 __psynch_cvwait + 8
1  libsystem_pthread.dylib        0x3f98 _pthread_cond_wait + 1204
2  FullStory                      0x8893c __fs_log_impl + 429448
3  FullStory                      0x2d3b8 __fs_log_impl + 55300
4  FullStory                      0xa21d0 rust_eh_personality + 24036
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-1
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x2bdf4 __fs_log_impl + 49728
5  FullStory                      0x2c990 __fs_log_impl + 52700
6  FullStory                      0x2ce9c __fs_log_impl + 53992
7  FullStory                      0xa21d0 rust_eh_personality + 24036
8  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
9  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-2
0  libsystem_kernel.dylib         0x7b78 __psynch_mutexwait + 8
1  libsystem_pthread.dylib        0x48a0 _pthread_mutex_firstfit_lock_wait + 84
2  libsystem_pthread.dylib        0x4250 _pthread_mutex_firstfit_lock_slow + 220
3  FullStory                      0x2cdbc __fs_log_impl + 53768
4  FullStory                      0xa21d0 rust_eh_personality + 24036
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

fs-default-3
0  libsystem_kernel.dylib         0x7b78 __psynch_mutexwait + 8
1  libsystem_pthread.dylib        0x48a0 _pthread_mutex_firstfit_lock_wait + 84
2  libsystem_pthread.dylib        0x4250 _pthread_mutex_firstfit_lock_slow + 220
3  FullStory                      0x2cdbc __fs_log_impl + 53768
4  FullStory                      0xa21d0 rust_eh_personality + 24036
5  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
6  libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x281b0 __fs_log_impl + 34300
5  FullStory                      0x4de84 __fs_log_impl + 189136
6  FullStory                      0x82798 __fs_log_impl + 404452
7  FullStory                      0xa21d0 rust_eh_personality + 24036
8  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
9  libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x281b0 __fs_log_impl + 34300
5  FullStory                      0x4de84 __fs_log_impl + 189136
6  FullStory                      0x7e60c __fs_log_impl + 387672
7  FullStory                      0x7ddd8 __fs_log_impl + 385572
8  FullStory                      0xa21d0 rust_eh_personality + 24036
9  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
10 libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x281b0 __fs_log_impl + 34300
5  FullStory                      0x4de84 __fs_log_impl + 189136
6  FullStory                      0x776f8 __fs_log_impl + 359236
7  FullStory                      0x76d94 __fs_log_impl + 356832
8  FullStory                      0xa21d0 rust_eh_personality + 24036
9  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
10 libsystem_pthread.dylib        0x1480 thread_start + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1510 __workq_kernreturn + 8
1  libsystem_pthread.dylib        0x36cc _pthread_wqthread + 364
2  libsystem_pthread.dylib        0x1474 start_wqthread + 8

Thread
0  libsystem_kernel.dylib         0x1704 semaphore_wait_trap + 8
1  libdispatch.dylib              0x4544 _dispatch_sema4_wait + 28
2  libdispatch.dylib              0x4bf8 _dispatch_semaphore_wait_slow + 132
3  FullStory                      0x9e3b4 rust_eh_personality + 8136
4  FullStory                      0x281b0 __fs_log_impl + 34300
5  FullStory                      0x4de84 __fs_log_impl + 189136
6  FullStory                      0x64520 __fs_log_impl + 280940
7  FullStory                      0xa21d0 rust_eh_personality + 24036
8  libsystem_pthread.dylib        0x17d0 _pthread_start + 136
9  libsystem_pthread.dylib        0x1480 thread_start + 8

@kirillzyusko
Copy link
Owner

@ethanneff just want to confirm - are you 100% sure that 2.502066.22 version has [email protected]+? Not 1.16.0 or lower?

If yes, then can I open a PR with a fix and ask you to apply those changes in your project with patch-package and check it if will be fixed in prod? (this is the only one way to check that the fix actually works I believe).

Thank you for being active on that issue 🙌

@kirillzyusko
Copy link
Owner

kirillzyusko commented Feb 12, 2025

@ethanneff may I kindly ask you to apply that patch: #805 and see if the crash got resolved or not?

@ethanneff
Copy link
Author

yes, we are on 1.16.2

      react-native-keyboard-controller:
        specifier: 1.16.2
        version: 1.16.2([email protected](@babel/[email protected])([email protected](@babel/[email protected])(@babel/[email protected](@babel/[email protected]))(@react-native-community/[email protected])(@types/[email protected])([email protected]))([email protected]))([email protected](@babel/[email protected])(@babel/[email protected](@babel/[email protected]))(@react-native-community/[email protected])(@types/[email protected])([email protected]))([email protected])

I can try #805. However, we are unable to reproduce the error on our staging environments - so we will have to see it in our canary deploy next week with real users.

@kirillzyusko
Copy link
Owner

@ethanneff yeah, okay, sure, let's wait next week 👍

Please, keep me updated 🤗

@ethanneff
Copy link
Author

We can close this out. The issue was related to version 1.16.0

@ethanneff ethanneff changed the title Fatal Exception: NSRangeException Cannot remove an observer <KeyboardMovementObserver 0x301d09cc0> for the key path "center" from <UIInputSetHostView 0x157fd7b10> because it is not registered as an observer. version 1.16.0 : Fatal Exception: NSRangeException Cannot remove an observer <KeyboardMovementObserver 0x301d09cc0> for the key path "center" from <UIInputSetHostView 0x157fd7b10> because it is not registered as an observer. Feb 15, 2025
@kirillzyusko
Copy link
Owner

Okay, awesome - glad it was solved in patch versions 😊

@liao02x
Copy link

liao02x commented Mar 13, 2025

I have seen this issue even from 1.16.2. The fix for me was to move the KeyboardProvider to a place that never re-renders (e.g. the root that only contains the KeyboardProvider that wraps the old root). After I did this, the crash never happens again. Hope this is helpful for others having this issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🎯 crash Library triggers a crash of the app 🍎 iOS iOS specific
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants