X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fui_config.cc;h=17ba896f1f92f938a8c0e5ed323e368dd212eec6;hb=3aa7dacfdf214f0db9330d975e94b7697a0259eb;hp=8e89884b22eaccbb925995c3bc7fe93c8c1a581d;hpb=ed626628b54e67dd9621c08d82a42afaed00c7ac;p=ardour.git diff --git a/gtk2_ardour/ui_config.cc b/gtk2_ardour/ui_config.cc index 8e89884b22..17ba896f1f 100644 --- a/gtk2_ardour/ui_config.cc +++ b/gtk2_ardour/ui_config.cc @@ -18,6 +18,7 @@ */ #include +#include #include /* for snprintf, grrr */ #include @@ -28,6 +29,8 @@ #include "pbd/file_utils.h" #include "pbd/error.h" +#include "gtkmm2ext/rgb_macros.h" + #include "ardour/ardour.h" #include "ardour/filesystem_paths.h" @@ -49,7 +52,7 @@ UIConfiguration::UIConfiguration () #include "canvas_vars.h" #undef UI_CONFIG_VARIABLE #undef CANVAS_VARIABLE - hack(true) + _dirty (false) { load_state(); } @@ -73,8 +76,7 @@ UIConfiguration::load_defaults () } if (find_file_in_search_path (ardour_search_path() + system_config_search_path(), - rcfile, default_ui_rc_file) ) - { + rcfile, default_ui_rc_file) ) { XMLTree tree; found = 1; @@ -91,6 +93,8 @@ UIConfiguration::load_defaults () error << string_compose(_("default ui configuration file \"%1\" not loaded successfully."), rcfile) << endmsg; return -1; } + + _dirty = false; } return found; @@ -104,8 +108,7 @@ UIConfiguration::load_state () sys::path default_ui_rc_file; if ( find_file_in_search_path (ardour_search_path() + system_config_search_path(), - "ardour3_ui_default.conf", default_ui_rc_file) ) - { + "ardour3_ui_default.conf", default_ui_rc_file) ) { XMLTree tree; found = true; @@ -127,8 +130,7 @@ UIConfiguration::load_state () sys::path user_ui_rc_file; if (find_file_in_search_path (ardour_search_path() + user_config_directory(), - "ardour3_ui.conf", user_ui_rc_file)) - { + "ardour3_ui.conf", user_ui_rc_file)) { XMLTree tree; found = true; @@ -145,12 +147,15 @@ UIConfiguration::load_state () error << string_compose(_("user ui configuration file \"%1\" not loaded successfully."), rcfile) << endmsg; return -1; } + + _dirty = false; } if (!found) error << _("could not find any ui configuration file, canvas will look broken.") << endmsg; pack_canvasvars(); + return 0; } @@ -181,6 +186,8 @@ UIConfiguration::save_state() } } + _dirty = false; + return 0; } @@ -229,6 +236,8 @@ UIConfiguration::set_state (const XMLNode& root, int /*version*/) return -1; } + Stateful::save_extra_xml (root); + XMLNodeList nlist = root.children(); XMLNodeConstIterator niter; XMLNode *node; @@ -236,14 +245,13 @@ UIConfiguration::set_state (const XMLNode& root, int /*version*/) for (niter = nlist.begin(); niter != nlist.end(); ++niter) { node = *niter; + if (node->name() == "Canvas" || node->name() == "UI") { set_variables (*node); - } else if (node->name() == "Extra") { - _extra_xml = new XMLNode (*node); - } } + return 0; } @@ -270,9 +278,32 @@ void UIConfiguration::pack_canvasvars () { #undef CANVAS_VARIABLE -#define CANVAS_VARIABLE(var,name) canvas_colors.push_back(&var); +#define CANVAS_VARIABLE(var,name) canvas_colors.insert (std::pair* >(name,&var)); #include "canvas_vars.h" #undef CANVAS_VARIABLE } +uint32_t +UIConfiguration::color_by_name (const std::string& name) +{ + map* >::iterator i = canvas_colors.find (name); + + if (i != canvas_colors.end()) { + return i->second->get(); + } + + // cerr << string_compose (_("Color %1 not found"), name) << endl; + return RGBA_TO_UINT (random()%256,random()%256,random()%256,0xff); +} + +void +UIConfiguration::set_dirty () +{ + _dirty = true; +} +bool +UIConfiguration::dirty () const +{ + return _dirty; +}