X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Faxis_view.cc;h=632289bddffe68254493669c1f10e02b1dfeff2a;hb=24d5f1a6249b08a8b21854ecf001be7e07e5bf23;hp=d87768703973d30c758e4a1b39d673a9b5e4bdf0;hpb=da7d7f950233f109f82f7e7ea5c62f81ef3d7bbb;p=ardour.git diff --git a/gtk2_ardour/axis_view.cc b/gtk2_ardour/axis_view.cc index d877687039..632289bddf 100644 --- a/gtk2_ardour/axis_view.cc +++ b/gtk2_ardour/axis_view.cc @@ -27,17 +27,19 @@ #include "pbd/error.h" #include "pbd/convert.h" +#include "pbd/i18n.h" #include #include #include +#include "ardour/selection.h" + #include "public_editor.h" #include "ardour_ui.h" #include "gui_object.h" #include "axis_view.h" #include "utils.h" -#include "i18n.h" using namespace std; using namespace Gtk; @@ -67,29 +69,54 @@ AxisView::gui_property (const string& property_name) const if (property_hashtable.count(property_name)) { return property_hashtable[property_name]; } else { - string rv = gui_object_state().get_string (state_id(), property_name); + string rv = gui_object_state().get_string (state_id(), property_name); property_hashtable.erase(property_name); property_hashtable.emplace(property_name, rv); return rv; } } +bool +AxisView::get_gui_property (const std::string& property_name, std::string& value) const +{ + std::string str = gui_property(property_name); + + if (!str.empty()) { + value = str; + return true; + } + + return false; +} + +void +AxisView::set_gui_property (const std::string& property_name, const std::string& value) +{ + property_hashtable.erase (property_name); + property_hashtable.emplace (property_name, value); + gui_object_state ().set_property (state_id (), property_name, value); +} + bool AxisView::marked_for_display () const { - string const v = gui_property ("visible"); - return (v == "" || PBD::string_is_affirmative (v)); + bool visible; + if (!get_gui_property ("visible", visible)) { + return true; + } + return visible; } bool AxisView::set_marked_for_display (bool yn) { - string const v = gui_property ("visible"); - if (v == "" || yn != PBD::string_is_affirmative (v)) { - set_gui_property ("visible", yn); - return true; // things changed + bool visible; + if (get_gui_property ("visible", visible) && visible == yn) { + return false; // nothing changed } - return false; + + set_gui_property ("visible", yn); + return true; // things changed } GUIObjectState& @@ -106,10 +133,4 @@ AxisView::set_selected (bool yn) } Selectable::set_selected (yn); - - boost::shared_ptr s = stripable (); - - if (s) { - s->presentation_info().set_selected (yn); - } }