* 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 "BranchList.h"
#include "Color.h"
+#include "ColorSet.h"
#include "frontends/Application.h"
+#include "support/lstrings.h"
+
#include <algorithm>
using namespace std;
namespace lyx {
-namespace {
-
-class BranchNamesEqual : public std::unary_function<Branch, bool>
+Branch::Branch()
+ : selected_(false), filenameSuffix_(false)
{
-public:
- BranchNamesEqual(docstring const & name) : name_(name) {}
-
- bool operator()(Branch const & branch) const
- {
- return branch.branch() == name_;
- }
-private:
- docstring name_;
-};
-}
-
-
-Branch::Branch() : selected_(false)
-{
- // no theApp() with command line export
- if (theApp())
- theApp()->getRgbColor(Color_background, color_);
+ color_ = "background";
}
}
-RGBColor const & Branch::color() const
+bool Branch::hasFileNameSuffix() const
{
- return color_;
+ return filenameSuffix_;
+}
+
+
+void Branch::setFileNameSuffix(bool b)
+{
+ filenameSuffix_ = b;
}
-void Branch::setColor(RGBColor const & c)
+string const & Branch::color() const
{
- color_ = c;
+ return color_;
}
void Branch::setColor(string const & str)
{
- if (str.size() == 7 && str[0] == '#')
- color_ = rgbFromHexName(str);
- else
- // no color set or invalid color - use normal background
- theApp()->getRgbColor(Color_background, color_);
+ color_ = str;
}
+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 =
- 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 =
- 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;
}
else
name = s.substr(i, j - i);
// Is this name already in the list?
- bool const already =
- 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);
+ 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();
}
{
if (newname.empty())
return false;
- if (find_if(list.begin(), list.end(),
- BranchNamesEqual(newname)) != list.end()) {
+ if (find(newname)) {
// new name already taken
if (merge)
return remove(oldname);
}
+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