From 5f4c624c5b0cdc71029b794c6ece5b566070c715 Mon Sep 17 00:00:00 2001 From: Michael Drake Date: Fri, 16 Aug 2013 12:23:37 +0100 Subject: [PATCH] Slight refactor of drag end handling, for future handling of more types of drag. --- desktop/treeview.c | 25 +++++++++++++++++-------- 1 file changed, 17 insertions(+), 8 deletions(-) diff --git a/desktop/treeview.c b/desktop/treeview.c index 4a57fb2ba..45b2d3a1b 100644 --- a/desktop/treeview.c +++ b/desktop/treeview.c @@ -1989,15 +1989,24 @@ void treeview_mouse_action(treeview *tree, assert(tree != NULL); assert(tree->root != NULL); - /* Handle selection drag end */ - if (mouse == BROWSER_MOUSE_HOVER && - tree->drag.type == TV_DRAG_SELECTION) { - treeview_commit_selection_drag(tree); - tree->drag.type = TV_DRAG_NONE; - tree->drag.start_node = NULL; + /* Handle drag ends */ + if (mouse == BROWSER_MOUSE_HOVER) { + switch (tree->drag.type) { + case TV_DRAG_SELECTION: + treeview_commit_selection_drag(tree); + tree->drag.type = TV_DRAG_NONE; + tree->drag.start_node = NULL; - tree->cw_t->drag_status(tree->cw_h, CORE_WINDOW_DRAG_NONE); - return; + tree->cw_t->drag_status(tree->cw_h, + CORE_WINDOW_DRAG_NONE); + return; + case TV_DRAG_MOVE: + /* TODO */ + break; + default: + /* No drag to end */ + break; + } } if (y > tree->root->height) {