]> git.lyx.org Git - lyx.git/blob - src/frontends/qt4/GuiToolbars.cpp
getting rid of superfluous lyx::support:: statements.
[lyx.git] / src / frontends / qt4 / GuiToolbars.cpp
1 /**
2  * \file GuiToolbars.cpp
3  * This file is part of LyX, the document processor.
4  * Licence details can be found in the file COPYING.
5  *
6  * \author Lars Gullik Bjønnes
7  * \author Angus Leeming
8  * \author Abdelrazak Younes
9  *
10  * Full author contact details are available in file CREDITS.
11  */
12
13 #include <config.h>
14
15 #include "GuiToolbars.h"
16
17 #include "GuiCommandBuffer.h"
18 #include "GuiToolbar.h"
19 #include "GuiView.h"
20
21 #include "Buffer.h"
22 #include "BufferParams.h"
23 #include "support/debug.h"
24 #include "FuncRequest.h"
25 #include "FuncStatus.h"
26 #include "support/gettext.h"
27 #include "Layout.h"
28 #include "LyX.h"
29 #include "LyXFunc.h"
30 #include "TextClass.h"
31 #include "ToolbarBackend.h"
32
33 using namespace std;
34
35 namespace lyx {
36 namespace frontend {
37
38 #define TurnOnFlag(x)   flags |= ToolbarInfo::x
39 #define TurnOffFlag(x)  flags &= ~ToolbarInfo::x
40
41 GuiToolbars::GuiToolbars(GuiView & owner)
42         : owner_(owner)
43 {
44         init();
45 }
46
47
48 void GuiToolbars::initFlags(ToolbarInfo & tbinfo)
49 {
50         ToolbarSection::ToolbarInfo & info = LyX::ref().session().toolbars().load(tbinfo.name);
51
52         unsigned int flags = static_cast<unsigned int>(tbinfo.flags);
53
54         // Remove default.ui positions. Only when a valid postion is stored
55         // in the session file the default.ui value will be overwritten
56         unsigned int save = flags;
57         TurnOffFlag(TOP);
58         TurnOffFlag(BOTTOM);
59         TurnOffFlag(RIGHT);
60         TurnOffFlag(LEFT);
61
62         bool valid_location = true;
63         // init tbinfo.flags with saved location
64         if (info.location == ToolbarSection::ToolbarInfo::TOP)
65                 TurnOnFlag(TOP);
66         else if (info.location == ToolbarSection::ToolbarInfo::BOTTOM)
67                 TurnOnFlag(BOTTOM);
68         else if (info.location == ToolbarSection::ToolbarInfo::RIGHT)
69                 TurnOnFlag(RIGHT);
70         else if (info.location == ToolbarSection::ToolbarInfo::LEFT)
71                 TurnOnFlag(LEFT);
72         else {
73                 // use setting from default.ui
74                 flags = save;
75                 valid_location = false;
76         }
77
78         // invalid location is for a new toolbar that has no saved information,
79         // so info.visible is not used for this case.
80         if (valid_location) {
81                 // init tbinfo.flags with saved visibility,
82                 TurnOffFlag(ON);
83                 TurnOffFlag(OFF);
84                 TurnOffFlag(AUTO);
85                 if (info.state == ToolbarSection::ToolbarInfo::ON)
86                         TurnOnFlag(ON);
87                 else if (info.state == ToolbarSection::ToolbarInfo::OFF)
88                         TurnOnFlag(OFF);
89                 else
90                         TurnOnFlag(AUTO);
91         }
92         /*
93         cout << "State " << info.state << " FLAGS: " << flags
94                 << " ON:" << (flags & ToolbarBackend::ON)
95                 << " OFF:" << (flags & ToolbarBackend::OFF)
96                 << " L:" << (flags & ToolbarBackend::LEFT)
97                 << " R:" << (flags & ToolbarBackend::RIGHT)
98                 << " T:" << (flags & ToolbarBackend::TOP)
99                 << " B:" << (flags & ToolbarBackend::BOTTOM)
100                 << " MA:" << (flags & ToolbarBackend::MATH)
101                 << " RE:" << (flags & ToolbarBackend::REVIEW)
102                 << " TB:" << (flags & ToolbarBackend::TABLE)
103                 << " AU:" << (flags & ToolbarBackend::AUTO)
104                 << endl;
105         */
106         // now set the flags
107         tbinfo.flags = static_cast<lyx::ToolbarInfo::Flags>(flags);
108 }
109
110
111 void GuiToolbars::init()
112 {
113         ToolbarsMap::const_iterator it = toolbars_.begin();
114         for (; it != toolbars_.end(); ++it)
115                 delete it->second;
116         toolbars_.clear();
117
118         // extracts the toolbars from the backend
119         ToolbarBackend::Toolbars::iterator cit = toolbarbackend.begin();
120         ToolbarBackend::Toolbars::iterator end = toolbarbackend.end();
121
122         // init flags will also add these toolbars to session if they
123         // are not already there (e.g. first run of lyx).
124         for (; cit != end; ++cit)
125                 initFlags(*cit);
126
127         // add toolbars according the order in session
128         ToolbarSection::ToolbarList::const_iterator tb =
129                 LyX::ref().session().toolbars().begin();
130         ToolbarSection::ToolbarList::const_iterator te =
131                 LyX::ref().session().toolbars().end();
132         ToolbarSection::ToolbarInfo::Location last_loc =
133                 ToolbarSection::ToolbarInfo::NOTSET;
134         int last_posx = 0;
135         int last_posy = 0;
136         for (; tb != te; ++tb) {
137                 LYXERR(Debug::INIT, "Adding " << tb->key << " at position "
138                         << tb->info.posx << " " << tb->info.posy);
139                 // add toolbar break if posx or posy changes
140                 bool newline = tb->info.location == last_loc && (
141                         // if two toolbars at the same location, assume uninitialized and add toolbar break
142                         (tb->info.posx == last_posx && tb->info.posy == last_posy) ||
143                         (last_loc == ToolbarSection::ToolbarInfo::TOP && tb->info.posy != last_posy) ||
144                         (last_loc == ToolbarSection::ToolbarInfo::BOTTOM && tb->info.posy != last_posy) ||
145                         (last_loc == ToolbarSection::ToolbarInfo::LEFT && tb->info.posx != last_posx) ||
146                         (last_loc == ToolbarSection::ToolbarInfo::RIGHT && tb->info.posx != last_posx) );
147                 // find the backend item and add
148                 for (cit = toolbarbackend.begin(); cit != end; ++cit)
149                         if (cit->name == tb->key) {
150                                 add(*cit, newline);
151                                 last_loc = tb->info.location;
152                                 last_posx = tb->info.posx;
153                                 last_posy = tb->info.posy;
154                                 break;
155                         }
156         }
157 }
158
159
160 void GuiToolbars::display(string const & name, bool show)
161 {
162         ToolbarBackend::Toolbars::iterator cit = toolbarbackend.begin();
163         ToolbarBackend::Toolbars::iterator end = toolbarbackend.end();
164
165         for (; cit != end; ++cit) {
166                 if (cit->name == name) {
167                         unsigned int flags = cit->flags;
168                         TurnOffFlag(ON);
169                         TurnOffFlag(OFF);
170                         TurnOffFlag(AUTO);
171                         if (show)
172                                 TurnOnFlag(ON);
173                         else
174                                 TurnOnFlag(OFF);
175                         cit->flags = static_cast<lyx::ToolbarInfo::Flags>(flags);
176                         displayToolbar(*cit, show);
177                 }
178         }
179
180         LYXERR(Debug::GUI, "Toolbar::display: no toolbar named " << name);
181 }
182
183
184 ToolbarInfo * GuiToolbars::getToolbarInfo(string const & name)
185 {
186         return toolbarbackend.getUsedToolbarInfo(name);
187 }
188
189
190 void GuiToolbars::toggleToolbarState(string const & name, bool allowauto)
191 {
192         ToolbarInfo * tbi = toolbarbackend.getUsedToolbarInfo(name);
193
194         if (!tbi) {
195                 LYXERR(Debug::GUI, "Toolbar::display: no toolbar named " << name);
196                 return;
197         }
198
199         int flags = tbi->flags;
200         // off -> on
201         if (flags & ToolbarInfo::OFF) {
202                 TurnOffFlag(OFF);
203                 TurnOnFlag(ON);
204         // auto -> off
205         } else if (flags & ToolbarInfo::AUTO) {
206                 TurnOffFlag(AUTO);
207                 TurnOnFlag(OFF);
208         } else if (allowauto 
209                    && ((flags & ToolbarInfo::MATH) 
210                        || (flags & ToolbarInfo::TABLE)
211                        || (flags & ToolbarInfo::REVIEW))) {
212                 // for math etc, toggle from on -> auto
213                 TurnOffFlag(ON);
214                 TurnOnFlag(AUTO);
215         } else {
216                 // for others, toggle from on -> off
217                 TurnOffFlag(ON);
218                 TurnOnFlag(OFF);
219         }
220         tbi->flags = static_cast<ToolbarInfo::Flags>(flags);
221 }
222 #undef TurnOnFlag
223 #undef TurnOffFlag
224
225
226 void GuiToolbars::update(bool in_math, bool in_table, bool review)
227 {
228         updateIcons();
229
230         // extracts the toolbars from the backend
231         ToolbarBackend::Toolbars::const_iterator cit = toolbarbackend.begin();
232         ToolbarBackend::Toolbars::const_iterator end = toolbarbackend.end();
233
234         for (; cit != end; ++cit) {
235                 if (cit->flags & ToolbarInfo::ON)
236                         displayToolbar(*cit, true);
237                 else if (cit->flags & ToolbarInfo::OFF)
238                         displayToolbar(*cit, false);
239                 else if ((cit->flags & ToolbarInfo::AUTO) && (cit->flags & ToolbarInfo::MATH))
240                         displayToolbar(*cit, in_math);
241                 else if ((cit->flags & ToolbarInfo::AUTO) && (cit->flags & ToolbarInfo::TABLE))
242                         displayToolbar(*cit, in_table);
243                 else if ((cit->flags & ToolbarInfo::AUTO) && (cit->flags & ToolbarInfo::REVIEW))
244                         displayToolbar(*cit, review);
245         }
246 }
247
248
249 bool GuiToolbars::visible(string const & name) const
250 {
251         map<string, GuiToolbar *>::const_iterator it =
252                 toolbars_.find(name);
253         if (it == toolbars_.end())
254                 return false;
255         return it->second->isVisible();
256 }
257
258
259 void GuiToolbars::saveToolbarInfo()
260 {
261         ToolbarSection & tb = LyX::ref().session().toolbars();
262
263         for (ToolbarBackend::Toolbars::iterator cit = toolbarbackend.begin();
264                 cit != toolbarbackend.end(); ++cit) {
265                 ToolbarsMap::iterator it = toolbars_.find(cit->name);
266                 BOOST_ASSERT(it != toolbars_.end());
267                 // get toolbar info from session.
268                 ToolbarSection::ToolbarInfo & info = tb.load(cit->name);
269                 if (cit->flags & ToolbarInfo::ON)
270                         info.state = ToolbarSection::ToolbarInfo::ON;
271                 else if (cit->flags & ToolbarInfo::OFF)
272                         info.state = ToolbarSection::ToolbarInfo::OFF;
273                 else if (cit->flags & ToolbarInfo::AUTO)
274                         info.state = ToolbarSection::ToolbarInfo::AUTO;
275                 // save other information
276                 // if auto, frontend should *not* set on/off
277                 it->second->saveInfo(info);
278                 // maybe it is useful to update flags with real status. I do not know
279                 /*
280                 if (!(cit->flags & ToolbarInfo::AUTO)) {
281                         unsigned int flags = static_cast<unsigned int>(cit->flags);
282                         flags &= ~(info.state == ToolbarSection::ToolbarInfo::ON ? ToolbarInfo::OFF : ToolbarInfo::ON);
283                         flags |= (info.state == ToolbarSection::ToolbarInfo::ON ? ToolbarInfo::ON : ToolbarInfo::OFF);
284                         if (info.state == ToolbarSection::ToolbarInfo::ON)
285                         cit->flags = static_cast<lyx::ToolbarInfo::Flags>(flags);
286                 }
287                 */
288         }
289 }
290
291
292 void GuiToolbars::add(ToolbarInfo const & tbinfo, bool newline)
293 {
294         GuiToolbar * tb_ptr = owner_.makeToolbar(tbinfo, newline);
295         toolbars_[tbinfo.name] = tb_ptr;
296
297         if (tbinfo.flags & ToolbarInfo::ON)
298                 tb_ptr->show();
299         else
300                 tb_ptr->hide();
301 }
302
303
304 void GuiToolbars::displayToolbar(ToolbarInfo const & tbinfo,
305                               bool show_it)
306 {
307         ToolbarsMap::iterator it = toolbars_.find(tbinfo.name);
308         BOOST_ASSERT(it != toolbars_.end());
309
310         if (show_it) {
311                 if (it->second->isVisible())
312                         return;
313                 it->second->show();
314         }
315         else if (it->second->isVisible())
316                 it->second->hide();
317 }
318
319
320 void GuiToolbars::updateIcons()
321 {
322         ToolbarsMap::const_iterator it = toolbars_.begin();
323         ToolbarsMap::const_iterator const end = toolbars_.end();
324         for (; it != end; ++it)
325                 it->second->updateContents();
326 }
327
328
329 void GuiToolbars::showCommandBuffer(bool show_it)
330 {
331         ToolbarsMap::const_iterator it = toolbars_.begin();
332         ToolbarsMap::const_iterator const end = toolbars_.end();
333         for (; it != end; ++it) {
334                 GuiCommandBuffer * cb = it->second->commandBuffer();
335                 if (!cb)
336                         continue;
337                 if (!show_it) {
338                         // FIXME: this is a hack, "minibuffer" should not be
339                         // hardcoded.
340                         display("minibuffer", false);
341                         return;
342                 }
343                 if (!it->second->isVisible())
344                         display("minibuffer", true);
345                 cb->setFocus();
346                 return;
347         }
348 }
349
350 } // namespace frontend
351 } // namespace lyx