2 * \file FormThesaurus.C
3 * Copyright 2001 The LyX Team.
4 * See the file COPYING.
6 * \author Edwin Leuven, leuven@fee.uva.nl
12 #pragma implementation
16 #include "support/lstrings.h"
18 #include "xforms_helpers.h"
19 #include "ControlThesaurus.h"
20 #include "FormThesaurus.h"
21 #include "form_thesaurus.h"
28 typedef FormCB<ControlThesaurus, FormDB<FD_form_thesaurus> > base_class;
31 FormThesaurus::FormThesaurus(ControlThesaurus & c)
32 : base_class(c, _("LyX: Thesaurus"), false),
38 void FormThesaurus::build()
40 dialog_.reset(build_thesaurus());
42 fl_set_input_return(dialog_->input_entry, FL_RETURN_CHANGED);
43 fl_set_input_return(dialog_->input_replace, FL_RETURN_CHANGED);
45 setPrehandler(dialog_->input_entry);
46 setPrehandler(dialog_->input_replace);
48 // Manage the ok, apply and cancel/close buttons
49 bc().setCancel(dialog_->button_close);
50 bc().addReadOnly(dialog_->input_replace);
52 fl_set_input_return(dialog_->input_entry, FL_RETURN_END_CHANGED);
56 void FormThesaurus::update()
61 string const & str_ = controller().text();
62 setEnabled(dialog_->button_replace, !str_.empty());
63 fl_set_input(dialog_->input_replace, "");
68 void FormThesaurus::updateMeanings(string const & str)
70 fl_clear_browser(dialog_->browser_meanings);
72 fl_set_input(dialog_->input_entry, str.c_str());
74 fl_set_browser_topline(dialog_->browser_meanings, 1);
76 fl_freeze_form(form());
78 Thesaurus::Meanings meanings = controller().getMeanings(str);
80 Thesaurus::Meanings::const_iterator cit = meanings.begin();
81 Thesaurus::Meanings::const_iterator end = meanings.end();
82 for (; cit != end; ++cit) {
83 fl_add_browser_line(dialog_->browser_meanings,
86 vector<string> const & tmpvec = cit->second;
87 vector<string>::const_iterator cit2 = tmpvec.begin();
88 vector<string>::const_iterator end2 = tmpvec.end();
89 for (; cit2 != end2; ++cit2) {
92 fl_add_browser_line(dialog_->browser_meanings,
97 fl_unfreeze_form(form());
98 fl_redraw_form(form());
102 void FormThesaurus::setReplace(string const & templ, string const & nstr)
106 // the following mechanism makes sure we replace "House" with "Home",
107 // "HOUSE" with "HOME" etc.
109 bool all_lower = true;
110 bool all_upper = true;
112 string::const_iterator beg = templ.begin();
113 string::const_iterator end = templ.end();
114 string::const_iterator cit = beg;
115 for (; cit != end; ++cit) {
123 str = lowercase(nstr);
124 } else if (all_upper) {
125 str = uppercase(nstr);
126 } else if (templ.size() > 0 && isupper(templ[0])) {
127 bool rest_lower = true;
128 string::const_iterator cit2 = beg + 1;
130 for (; cit2 != end; ++cit2) {
136 str = lowercase(nstr);
137 str[0] = uppercase(nstr[0]);
141 fl_set_input(dialog_->input_replace, str.c_str());
145 ButtonPolicy::SMInput FormThesaurus::input(FL_OBJECT * obj, long)
147 if (obj == dialog_->input_entry) {
148 string s = strip(frontStrip(fl_get_input(dialog_->input_entry)));
153 fl_set_input(dialog_->input_replace, "");
154 return ButtonPolicy::SMI_APPLY;
156 return ButtonPolicy::SMI_NOOP;
158 } else if (obj == dialog_->button_replace) {
159 string rep(fl_get_input(dialog_->input_replace));
161 controller().replace(fl_get_input(dialog_->input_replace));
164 return ButtonPolicy::SMI_APPLY;
165 } else if (obj != dialog_->browser_meanings) {
166 return ButtonPolicy::SMI_NOOP;
169 int const line = fl_get_browser(obj);
171 setReplace(fl_get_input(dialog_->input_entry),
172 strip(frontStrip(fl_get_browser_line(obj, line))));
175 if (clickline_ == fl_get_browser(obj)) {
176 updateMeanings(fl_get_input(dialog_->input_replace));
179 clickline_ = fl_get_browser(obj);
182 return ButtonPolicy::SMI_VALID;