+bool BranchList::rename(docstring const & oldname,
+ docstring const & newname, bool const merge)
+{
+ if (newname.empty())
+ return false;
+ if (find_if(list.begin(), list.end(),
+ BranchNamesEqual(newname)) != list.end()) {
+ // 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;
+ List::const_iterator it = list.begin();
+ for (; it != list.end(); ++it) {
+ if (it->isSelected() && it->hasFilenameSuffix())
+ result += "-" + it->branch();
+ }
+ return support::subst(result, from_ascii("/"), from_ascii("_"));
+}
+