diff --git a/crates/gpui/src/platform/mac/screen.rs b/crates/gpui/src/platform/mac/screen.rs index 98b6a66f03842a063adfe93209a0d6e0d8985684..3766a13de3aaa6b86cd4299683e5d2a2b52d7428 100644 --- a/crates/gpui/src/platform/mac/screen.rs +++ b/crates/gpui/src/platform/mac/screen.rs @@ -65,8 +65,15 @@ impl platform::Screen for Screen { // This approach is similar to that which winit takes // https://github.com/rust-windowing/winit/blob/402cbd55f932e95dbfb4e8b5e8551c49e56ff9ac/src/platform_impl/macos/monitor.rs#L99 let device_description = self.native_screen.deviceDescription(); + let key = ns_string("NSScreenNumber"); let device_id_obj = device_description.objectForKey_(key); + if device_id_obj.is_null() { + // Under some circumstances, especially display re-arrangements or display locking, we seem to get a null pointer + // to the device id. See: https://linear.app/zed-industries/issue/Z-257/lock-screen-crash-with-multiple-monitors + return None; + } + let mut device_id: u32 = 0; CFNumberGetValue( device_id_obj as CFNumberRef,