#include <config.h>
#include "FormBranch.h"
-#include "ControlBranch.h"
#include "forms/form_branch.h"
-
#include "xformsBC.h"
+#include "BranchList.h"
+
+#include "controllers/ControlBranch.h"
+
#include "insets/insetbranch.h"
#include "lyx_forms.h"
-
using std::string;
void FormBranch::build()
{
- string all_branches(controller().params().branchlist.allBranches());
-
dialog_.reset(build_branch(this));
- fl_addto_choice(dialog_->choice_branch, all_branches.c_str());
-
bcview().setOK(dialog_->button_ok);
bcview().setApply(dialog_->button_apply);
bcview().setCancel(dialog_->button_cancel);
void FormBranch::update()
{
- // Make changes in all_branches propagate within session:
- string all_branches(controller().params().branchlist.allBranches());
+ typedef BranchList::const_iterator const_iterator;
+
+ BranchList const & branchlist = controller().branchlist();
+ string const cur_branch = controller().params().branch;
+
fl_clear_choice(dialog_->choice_branch);
- fl_addto_choice(dialog_->choice_branch, all_branches.c_str());
- string branch(controller().params().branch);
- if (all_branches.find(branch) != string::npos && branch != "none")
- fl_set_choice_text(dialog_->choice_branch, branch.c_str());
+ const_iterator const begin = branchlist.begin();
+ const_iterator const end = branchlist.end();
+ int id = 1;
+ int count = 1;
+ for (const_iterator it = begin; it != end; ++it, ++count) {
+ string const & branch = it->getBranch();
+ fl_addto_choice(dialog_->choice_branch, branch.c_str());
+
+ if (cur_branch == branch)
+ id = count;
+ }
+ fl_set_choice(dialog_->choice_branch, id);
}
void FormBranch::apply()
{
string const type = fl_get_choice_text(dialog_->choice_branch);
-
controller().params().branch = type;
}