X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fconfiguration_variable.h;h=a7fe8def48169c17c508ca714ffc135a1ea9bfb9;hb=cc7d4db5fe9132c38b919ab073b91d442abad9b6;hp=fa53b6a1c4f16ed609df8bfdb75851232a0d69bf;hpb=7f9cab8c2883611979e52f2e7b5a4fca09f6b93b;p=ardour.git diff --git a/libs/ardour/ardour/configuration_variable.h b/libs/ardour/ardour/configuration_variable.h index fa53b6a1c4..a7fe8def48 100644 --- a/libs/ardour/ardour/configuration_variable.h +++ b/libs/ardour/ardour/configuration_variable.h @@ -24,6 +24,7 @@ #include #include "pbd/xml++.h" +#include "pbd/convert.h" #include "ardour/types.h" #include "ardour/utils.h" @@ -88,6 +89,42 @@ class ConfigVariable : public ConfigVariableBase T value; }; +/** Specialisation of ConfigVariable for std::string to cope with whitespace properly */ +template<> +class ConfigVariable : public ConfigVariableBase +{ + public: + + ConfigVariable (std::string str) : ConfigVariableBase (str) {} + ConfigVariable (std::string str, std::string val) : ConfigVariableBase (str), value (val) {} + + std::string get() const { + return value; + } + + std::string get_as_string () const { + return value; + } + + virtual bool set (std::string val) { + if (val == value) { + miss (); + return false; + } + value = val; + notify (); + return true; + } + + virtual void set_from_string (std::string const & s) { + value = s; + } + + protected: + virtual std::string get_for_save() { return value; } + std::string value; +}; + template<> class ConfigVariable : public ConfigVariableBase { @@ -117,7 +154,7 @@ class ConfigVariable : public ConfigVariableBase } void set_from_string (std::string const & s) { - value = string_is_affirmative (s); + value = PBD::string_is_affirmative (s); } protected: @@ -141,11 +178,11 @@ class ConfigVariableWithMutation : public ConfigVariable } void set_from_string (std::string const & s) { - T v; - std::stringstream ss; - ss << s; + T v; + std::stringstream ss; + ss << s; ss >> v; - set (v); + set (v); } protected: