* Licence details can be found in the file COPYING.
*
* \author Martin Vermeer
+ * \author Jürgen Spitzmüller
*
* Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "BranchList.h"
-#include "LColor.h"
+#include "Color.h"
+#include "ColorSet.h"
#include "frontends/Application.h"
-#include <algorithm>
-
+#include "support/convert.h"
+#include "support/lstrings.h"
-namespace lyx {
+#include <algorithm>
-using std::string;
+using namespace std;
-Branch::Branch()
-{
- theApp()->getRgbColor(LColor::background, color_);
-}
-
+namespace lyx {
-docstring const & Branch::getBranch() const
+docstring const & Branch::branch() const
{
return branch_;
}
}
-bool Branch::getSelected() const
+bool Branch::isSelected() const
{
return selected_;
}
}
-RGBColor const & Branch::getColor() const
+bool Branch::hasFileNameSuffix() const
+{
+ return filenameSuffix_;
+}
+
+
+void Branch::setFileNameSuffix(bool b)
+{
+ filenameSuffix_ = b;
+}
+
+
+string const & Branch::color() const
{
- return color_;
+ return (theApp() && theApp()->isInDarkMode())
+ ? dmcolor_ : lmcolor_;
}
-void Branch::setColor(RGBColor const & c)
+string const & Branch::lightModeColor() const
{
- color_ = c;
+ return lmcolor_;
}
-void Branch::setColor(string const & c)
+string const & Branch::darkModeColor() const
{
- if (c.size() == 7 && c[0] == '#')
- color_ = RGBColor(c);
+ return dmcolor_;
+}
+
+
+void Branch::setColor(string const & col)
+{
+ if (theApp() && theApp()->isInDarkMode())
+ setColors(string(), col);
else
- // no color set or invalid color - use normal background
- theApp()->getRgbColor(LColor::background, color_);
+ setColors(col);
+}
+
+
+void Branch::setColors(string const & lmcol, string const & dmcol)
+{
+ if (lmcol.empty() && lmcolor_ == "background" && support::prefixIs(dmcol, "#"))
+ lmcolor_ = X11hexname(inverseRGBColor(rgbFromHexName(dmcol)));
+ else if (!lmcol.empty())
+ lmcolor_ = lmcol;
+ if (dmcol.empty() && dmcolor_ == "background" && support::prefixIs(lmcol, "#"))
+ dmcolor_ = X11hexname(inverseRGBColor(rgbFromHexName(lmcol)));
+ else if (!dmcol.empty())
+ dmcolor_ = dmcol;
+
+ // Update the Color table
+ string lmcolor = lmcolor_;
+ string dmcolor = dmcolor_;
+ if (lmcolor == "none")
+ lmcolor = lcolor.getX11HexName(Color_background);
+ else if (lmcolor.size() != 7 || lmcolor[0] != '#')
+ lmcolor = lcolor.getX11HexName(lcolor.getFromLyXName(lmcolor));
+ if (dmcolor == "none")
+ dmcolor = lcolor.getX11HexName(Color_background, true);
+ else if (dmcolor.size() != 7 || dmcolor[0] != '#')
+ dmcolor = lcolor.getX11HexName(lcolor.getFromLyXName(dmcolor), true);
+
+ // FIXME UNICODE
+ lcolor.setColor("branch" + convert<string>(branch_list_id_)
+ + to_utf8(branch_), lmcolor, dmcolor);
}
+namespace {
+
+std::function<bool (Branch const &)> BranchNameIs(docstring const & d)
+{
+ return [d](Branch const & b){ return b.branch() == d; };
+}
+
+} // namespace
+
+
Branch * BranchList::find(docstring const & name)
{
List::iterator it =
- std::find_if(list.begin(), list.end(), BranchNamesEqual(name));
- return it == list.end() ? 0 : &*it;
+ find_if(list_.begin(), list_.end(), BranchNameIs(name));
+ return it == list_.end() ? nullptr : &*it;
}
Branch const * BranchList::find(docstring const & name) const
{
List::const_iterator it =
- std::find_if(list.begin(), list.end(), BranchNamesEqual(name));
- return it == list.end() ? 0 : &*it;
+ find_if(list_.begin(), list_.end(), BranchNameIs(name));
+ return it == list_.end() ? nullptr : &*it;
}
bool BranchList::add(docstring const & s)
{
bool added = false;
- docstring::size_type i = 0;
+ size_t i = 0;
while (true) {
- docstring::size_type const j = s.find_first_of(separator_, i);
+ size_t 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);
// Is this name already in the list?
- bool const already =
- std::find_if(list.begin(), list.end(),
- BranchNamesEqual(name)) != list.end();
+ bool const already = find(name);
if (!already) {
added = true;
Branch br;
br.setBranch(name);
br.setSelected(false);
- list.push_back(br);
+ br.setFileNameSuffix(false);
+ br.setListID(id_);
+ list_.push_back(br);
}
if (j == docstring::npos)
break;
bool BranchList::remove(docstring const & s)
{
- size_t const size = list.size();
- list.remove_if(BranchNamesEqual(s));
- return size != list.size();
+ size_t const size = list_.size();
+ list_.remove_if(BranchNameIs(s));
+ return size != list_.size();
+}
+
+
+bool BranchList::rename(docstring const & oldname,
+ docstring const & newname, bool const merge)
+{
+ if (newname.empty())
+ return false;
+ if (find(newname)) {
+ // new name already taken
+ if (merge)
+ return remove(oldname);
+ return false;
+ }
+
+ Branch * branch = find(oldname);
+ if (!branch)
+ return false;
+ branch->setBranch(newname);
+ return true;
}
+docstring BranchList::getFileNameSuffix() const
+{
+ docstring result;
+ for (auto const & br : list_) {
+ if (br.isSelected() && br.hasFileNameSuffix())
+ result += "-" + br.branch();
+ }
+ return support::subst(result, from_ascii("/"), from_ascii("_"));
+}
+
} // namespace lyx