From 06e01e4cb337c11f9aacc8523283584f1f32f71f Mon Sep 17 00:00:00 2001 From: Rob Saunders Date: Thu, 27 Jul 2017 10:56:34 +0800 Subject: [PATCH] Added event for cancelling a drag and drop. --- src/events.rs | 7 +++++-- src/platform/macos/window.rs | 18 +++++++++--------- 2 files changed, 14 insertions(+), 11 deletions(-) diff --git a/src/events.rs b/src/events.rs index ecd53013..bc72672c 100644 --- a/src/events.rs +++ b/src/events.rs @@ -26,11 +26,14 @@ pub enum WindowEvent { /// The window has been closed. Closed, + /// A file has been dropped into the window. + DroppedFile(PathBuf), + /// A file is being hovered over the window. HoveredFile(PathBuf), - /// A file has been dropped into the window. - DroppedFile(PathBuf), + /// A file was hovered, but has exited the window. + HoveredFileCancelled, /// The window received a unicode character. ReceivedCharacter(char), diff --git a/src/platform/macos/window.rs b/src/platform/macos/window.rs index af96ad8a..95e2bce2 100644 --- a/src/platform/macos/window.rs +++ b/src/platform/macos/window.rs @@ -143,9 +143,7 @@ impl WindowDelegate { } /// Invoked when the image is released - extern fn prepare_for_drag_operation(_: &Object, _: Sel, _: id) { - println!("prepare_for_drag_operation"); - } + extern fn prepare_for_drag_operation(_: &Object, _: Sel, _: id) {} /// Invoked after the released image has been removed from the screen extern fn perform_drag_operation(this: &Object, _: Sel, sender: id) -> BOOL { @@ -174,13 +172,15 @@ impl WindowDelegate { } /// Invoked when the dragging operation is complete - extern fn conclude_drag_operation(_: &Object, _: Sel, _: id) { - println!("conclude_drag_operation"); - } + extern fn conclude_drag_operation(_: &Object, _: Sel, _: id) {} /// Invoked when the dragging operation is cancelled - extern fn dragging_exited(_: &Object, _: Sel, _: id) { - println!("dragging_exited"); + extern fn dragging_exited(this: &Object, _: Sel, _: id) { + unsafe { + let state: *mut c_void = *this.get_ivar("winitState"); + let state = &mut *(state as *mut DelegateState); + emit_event(state, WindowEvent::HoveredFileCancelled); + } } static mut DELEGATE_CLASS: *const Class = 0 as *const Class; @@ -204,7 +204,7 @@ impl WindowDelegate { decl.add_method(sel!(windowDidResignKey:), window_did_resign_key as extern fn(&Object, Sel, id)); - // callback for drag events + // callbacks for drag and drop events decl.add_method(sel!(draggingEntered:), dragging_entered as extern fn(&Object, Sel, id) -> BOOL); decl.add_method(sel!(prepareForDragOperation:),