Mercurial > geeqie.yaz
changeset 1395:e86d8facbdae
dnd fixes
author | nadvornik |
---|---|
date | Sun, 08 Mar 2009 11:32:12 +0000 |
parents | bec57fa486f4 |
children | 58f0b4586c8c |
files | src/bar_keywords.c |
diffstat | 1 files changed, 11 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/src/bar_keywords.c Sun Mar 08 10:38:51 2009 +0000 +++ b/src/bar_keywords.c Sun Mar 08 11:32:12 2009 +0000 @@ -572,6 +572,11 @@ gtk_tree_path_free(tpath); gtk_tree_model_filter_convert_iter_to_child_iter(GTK_TREE_MODEL_FILTER(model), &dest_kw_iter, &dest_iter); + if (src_valid && gtk_tree_store_is_ancestor(GTK_TREE_STORE(keyword_tree), &src_kw_iter, &dest_kw_iter)) + { + /* can't move to it's own child */ + return; + } if ((pos == GTK_TREE_VIEW_DROP_INTO_OR_BEFORE || pos == GTK_TREE_VIEW_DROP_INTO_OR_AFTER) && !gtk_tree_model_iter_has_child(keyword_tree, &dest_kw_iter)) @@ -640,7 +645,12 @@ gtk_tree_view_set_drag_dest_row(GTK_TREE_VIEW(tree_view), tpath, pos); gtk_tree_path_free(tpath); - gdk_drag_status(context, GDK_ACTION_COPY, time); + + if (tree_view == gtk_drag_get_source_widget(context)) + gdk_drag_status(context, GDK_ACTION_MOVE, time); + else + gdk_drag_status(context, GDK_ACTION_COPY, time); + return TRUE; }