From 45b86c4816f430017f8d3015470d8e778240ed30 Mon Sep 17 00:00:00 2001 From: eidheim Date: Sun, 10 Apr 2016 11:39:24 +0200 Subject: [PATCH] Cleanup and improvements related to #187: right click menu operations in directory view --- src/directories.cc | 36 ++++++++++++++++++++++++++---------- 1 file changed, 26 insertions(+), 10 deletions(-) diff --git a/src/directories.cc b/src/directories.cc index e514a5e..e07b437 100644 --- a/src/directories.cc +++ b/src/directories.cc @@ -63,8 +63,10 @@ bool Directories::TreeStore::drag_data_received_vfunc(const TreeModel::Path &pat auto it=directories.get_selection()->get_selected(); if(it) { auto source_path=it->get_value(directories.column_record.path); - auto target_path=get_target_folder(path); + if(source_path.empty()) + return false; + auto target_path=get_target_folder(path); target_path/=source_path.filename(); if(source_path==target_path) @@ -218,7 +220,7 @@ Directories::Directories() : Gtk::TreeView(), stop_update_thread(false) { auto target_path=source_path->parent_path()/content; boost::filesystem::rename(*source_path, target_path, ec); if(ec) - Terminal::get().print("Error: could not rename "+source_path->string()+": "+ec.message()+'\n'); + Terminal::get().print("Error: could not rename "+source_path->string()+": "+ec.message()+'\n', true); else { update(); select(target_path); @@ -297,7 +299,7 @@ Directories::Directories() : Gtk::TreeView(), stop_update_thread(false) { }); menu.append(menu_item_delete); - auto create_file_label = "Create file"; + auto create_file_label = "Create File"; auto create_file_signal = [this] { if(menu_popup_row_path.empty()) return; @@ -306,14 +308,16 @@ Directories::Directories() : Gtk::TreeView(), stop_update_thread(false) { EntryBox::get().entries.emplace_back("", [this, source_path](const std::string &content){ bool is_directory=boost::filesystem::is_directory(*source_path); auto target_path = (is_directory ? *source_path : source_path->parent_path())/content; - if(!boost::filesystem::exists(target_path)) - { - filesystem::write(target_path, ""); - Notebook::get().open(target_path); + if(!boost::filesystem::exists(target_path)) { + if(filesystem::write(target_path, "")) { + update(); + Notebook::get().open(target_path); + } + else + Terminal::get().print("Error: could not create "+target_path.string()+'\n', true); } else - Terminal::get().print("Cannot create "+target_path.string()+": file already exists.\n", true); - update(); + Terminal::get().print("Error: could not create "+target_path.string()+": file already exists\n", true); EntryBox::get().hide(); }); @@ -446,15 +450,27 @@ void Directories::select(const boost::filesystem::path &select_path) { bool Directories::on_button_press_event(GdkEventButton* event) { if(event->type==GDK_BUTTON_PRESS && event->button==GDK_BUTTON_SECONDARY) { + EntryBox::get().hide(); Gtk::TreeModel::Path path; if(get_path_at_pos(static_cast(event->x), static_cast(event->y), path)) { menu_popup_row_path=get_model()->get_iter(path)->get_value(column_record.path); + if(menu_popup_row_path.empty()) { + auto parent=get_model()->get_iter(path)->parent(); + if(parent) + menu_popup_row_path=parent->get_value(column_record.path); + else { + menu_popup_row_path=this->path; + menu_root.popup(event->button, event->time); + return true; + } + } menu.popup(event->button, event->time); return true; } - else { + else if(!this->path.empty()) { menu_popup_row_path=this->path; menu_root.popup(event->button, event->time); + return true; } }