]> git.lyx.org Git - lyx.git/blobdiff - src/BranchList.C
* src/LaTeX.C: beautification: use identical user messages
[lyx.git] / src / BranchList.C
index 6d89551b74c9c8235155327d46d387c744d63bac..44c98e4a7007beac6d81e9f8fcc9e564b62445cb 100644 (file)
 #include <config.h>
 
 #include "BranchList.h"
+#include "LColor.h"
+
+#include "frontends/Application.h"
+
 #include <algorithm>
 
+
+namespace lyx {
+
 using std::string;
 
 
-string const & Branch::getBranch() const
+Branch::Branch()
+{
+       theApp->getRgbColor(LColor::background, color_);
+}
+
+
+docstring const & Branch::getBranch() const
 {
        return branch_;
 }
 
 
-void Branch::setBranch(string const & s)
+void Branch::setBranch(docstring const & s)
 {
        branch_ = s;
 }
@@ -43,19 +56,29 @@ bool Branch::setSelected(bool b)
 }
 
 
-string const & Branch::getColor() const
+RGBColor const & Branch::getColor() const
 {
        return color_;
 }
 
 
-void Branch::setColor(string const & c)
+void Branch::setColor(RGBColor const & c)
 {
        color_ = c;
 }
 
 
-Branch * BranchList::find(std::string const & name)
+void Branch::setColor(string const & c)
+{
+       if (c.size() == 7 && c[0] == '#')
+               color_ = RGBColor(c);
+       else
+               // no color set or invalid color - use normal background
+               theApp->getRgbColor(LColor::background, color_);
+}
+
+
+Branch * BranchList::find(docstring const & name)
 {
        List::iterator it =
                std::find_if(list.begin(), list.end(), BranchNamesEqual(name));
@@ -63,7 +86,7 @@ Branch * BranchList::find(std::string const & name)
 }
 
 
-Branch const * BranchList::find(std::string const & name) const
+Branch const * BranchList::find(docstring const & name) const
 {
        List::const_iterator it =
                std::find_if(list.begin(), list.end(), BranchNamesEqual(name));
@@ -71,14 +94,14 @@ Branch const * BranchList::find(std::string const & name) const
 }
 
 
-bool BranchList::add(string const & s)
+bool BranchList::add(docstring const & s)
 {
        bool added = false;
-       string::size_type i = 0;
+       docstring::size_type i = 0;
        while (true) {
-               string::size_type const j = s.find_first_of(separator_, i);
-               string name;
-               if (j == string::npos)
+               docstring::size_type const j = s.find_first_of(separator_, i);
+               docstring name;
+               if (j == docstring::npos)
                        name = s.substr(i);
                else
                        name = s.substr(i, j - i);
@@ -91,10 +114,9 @@ bool BranchList::add(string const & s)
                        Branch br;
                        br.setBranch(name);
                        br.setSelected(false);
-                       br.setColor("none");
                        list.push_back(br);
                }
-               if (j == string::npos)
+               if (j == docstring::npos)
                        break;
                i = j + 1;
        }
@@ -102,9 +124,12 @@ bool BranchList::add(string const & s)
 }
 
 
-bool BranchList::remove(string const & s)
+bool BranchList::remove(docstring const & s)
 {
-       List::size_type const size = list.size();
+       size_t const size = list.size();
        list.remove_if(BranchNamesEqual(s));
        return size != list.size();
 }
+
+
+} // namespace lyx