3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
6 * \author Lars Gullik Bjønnes
8 * \author Abdelrazak Younes
11 * Full author contact details are available in file CREDITS.
18 #include "GuiImplementation.h"
19 #include "GuiWorkArea.h"
20 #include "GuiKeySymbol.h"
21 #include "GuiMenubar.h"
22 #include "GuiToolbar.h"
23 #include "GuiToolbars.h"
27 #include "qt_helpers.h"
29 #include "frontends/Application.h"
30 #include "frontends/Dialogs.h"
31 #include "frontends/Gui.h"
33 #include "support/filetools.h"
34 #include "support/convert.h"
35 #include "support/lstrings.h"
36 #include "support/os.h"
38 #include "buffer_funcs.h"
40 #include "BufferList.h"
41 #include "BufferParams.h"
42 #include "BufferView.h"
45 #include "ErrorList.h"
46 #include "FuncRequest.h"
53 #include "MenuBackend.h"
54 #include "Paragraph.h"
55 #include "TextClass.h"
57 #include "ToolbarBackend.h"
60 #include "support/lstrings.h"
61 #include "support/filetools.h" // OnlyFilename()
62 #include "support/Timeout.h"
65 #include <QApplication>
66 #include <QCloseEvent>
67 #include <QDesktopWidget>
68 #include <QDragEnterEvent>
74 #include <QPushButton>
78 #include <QStackedWidget>
83 #include <boost/bind.hpp>
84 #include <boost/current_function.hpp>
86 #ifdef HAVE_SYS_TIME_H
87 # include <sys/time.h>
103 using support::bformat;
104 using support::FileName;
105 using support::makeDisplayPath;
106 using support::onlyFilename;
110 int const statusbar_timer_value = 3000;
112 class BackgroundWidget : public QWidget
115 BackgroundWidget(QString const & file, QString const & text)
117 splash_ = new QPixmap(file);
119 lyxerr << "could not load splash screen: '" << fromqstr(file) << "'" << endl;
123 QPainter pain(splash_);
124 pain.setPen(QColor(255, 255, 0));
126 // The font used to display the version info
127 font.setStyleHint(QFont::SansSerif);
128 font.setWeight(QFont::Bold);
129 font.setPointSize(convert<int>(lyxrc.font_sizes[FONT_SIZE_LARGE]));
131 pain.drawText(260, 270, text);
134 void paintEvent(QPaintEvent *)
139 int x = (width() - splash_->width()) / 2;
140 int y = (height() - splash_->height()) / 2;
142 pain.drawPixmap(x, y, *splash_);
152 struct GuiView::GuiViewPrivate
155 : current_work_area_(0), posx_offset(0), posy_offset(0)
162 delete stack_widget_;
167 unsigned int smallIconSize;
168 unsigned int normalIconSize;
169 unsigned int bigIconSize;
170 // static needed by "New Window"
171 static unsigned int lastIconSize;
173 QMenu * toolBarPopup(GuiView * parent)
175 // FIXME: translation
176 QMenu * menu = new QMenu(parent);
177 QActionGroup * iconSizeGroup = new QActionGroup(parent);
179 QAction * smallIcons = new QAction(iconSizeGroup);
180 smallIcons->setText(qt_("Small-sized icons"));
181 smallIcons->setCheckable(true);
182 QObject::connect(smallIcons, SIGNAL(triggered()),
183 parent, SLOT(smallSizedIcons()));
184 menu->addAction(smallIcons);
186 QAction * normalIcons = new QAction(iconSizeGroup);
187 normalIcons->setText(qt_("Normal-sized icons"));
188 normalIcons->setCheckable(true);
189 QObject::connect(normalIcons, SIGNAL(triggered()),
190 parent, SLOT(normalSizedIcons()));
191 menu->addAction(normalIcons);
193 QAction * bigIcons = new QAction(iconSizeGroup);
194 bigIcons->setText(qt_("Big-sized icons"));
195 bigIcons->setCheckable(true);
196 QObject::connect(bigIcons, SIGNAL(triggered()),
197 parent, SLOT(bigSizedIcons()));
198 menu->addAction(bigIcons);
200 unsigned int cur = parent->iconSize().width();
201 if ( cur == parent->d.smallIconSize)
202 smallIcons->setChecked(true);
203 else if (cur == parent->d.normalIconSize)
204 normalIcons->setChecked(true);
205 else if (cur == parent->d.bigIconSize)
206 bigIcons->setChecked(true);
211 void initBackground()
213 LYXERR(Debug::GUI) << "show banner: " << lyxrc.show_banner << endl;
214 /// The text to be written on top of the pixmap
215 QString const text = lyx_version ? QString(lyx_version) : qt_("unknown version");
216 bg_widget_ = new BackgroundWidget(":/images/banner.png", text);
221 stack_widget_->setCurrentWidget(bg_widget_);
222 bg_widget_->setUpdatesEnabled(true);
225 TabWorkArea * tabWorkArea(int i)
227 return dynamic_cast<TabWorkArea *>(splitter_->widget(i));
230 TabWorkArea * currentTabWorkArea()
232 if (splitter_->count() == 1)
233 // The first TabWorkArea is always the first one, if any.
234 return tabWorkArea(0);
236 TabWorkArea * tab_widget = 0;
237 for (int i = 0; i != splitter_->count(); ++i) {
238 QWidget * w = splitter_->widget(i);
241 tab_widget = dynamic_cast<TabWorkArea *>(w);
253 GuiWorkArea * current_work_area_;
257 QSplitter * splitter_;
258 QStackedWidget * stack_widget_;
259 BackgroundWidget * bg_widget_;
261 GuiMenubar * menubar_;
263 GuiToolbars * toolbars_;
265 docstring current_layout;
269 unsigned int GuiView::GuiViewPrivate::lastIconSize = 0;
272 GuiView::GuiView(int id)
273 : QMainWindow(), LyXView(id),
274 d(*new GuiViewPrivate),
275 quitting_by_menu_(false),
276 autosave_timeout_(new Timeout(5000)),
277 dialogs_(new Dialogs(*this))
279 // Start autosave timer
280 if (lyxrc.autosave) {
281 autosave_timeout_->timeout.connect(boost::bind(&GuiView::autoSave, this));
282 autosave_timeout_->setTimeout(lyxrc.autosave * 1000);
283 autosave_timeout_->start();
286 // Qt bug? signal lastWindowClosed does not work
287 setAttribute(Qt::WA_QuitOnClose, false);
288 setAttribute(Qt::WA_DeleteOnClose, true);
290 // hardcode here the platform specific icon size
291 d.smallIconSize = 14; // scaling problems
292 d.normalIconSize = 20; // ok, default
293 d.bigIconSize = 26; // better for some math icons
296 // assign an icon to main form. We do not do it under Qt/Mac,
297 // since the icon is provided in the application bundle.
298 setWindowIcon(QPixmap(":/images/lyx.png"));
302 d.splitter_ = new QSplitter;
305 LYXERR(Debug::GUI) << "stack widget!" << endl;
306 d.stack_widget_ = new QStackedWidget;
307 d.stack_widget_->addWidget(d.bg_widget_);
308 d.stack_widget_->addWidget(d.splitter_);
309 setCentralWidget(d.stack_widget_);
312 setAcceptDrops(true);
319 delete autosave_timeout_;
324 void GuiView::close()
326 quitting_by_menu_ = true;
327 d.current_work_area_ = 0;
328 for (int i = 0; i != d.splitter_->count(); ++i) {
329 TabWorkArea * twa = d.tabWorkArea(i);
333 QMainWindow::close();
334 quitting_by_menu_ = false;
338 void GuiView::setFocus()
340 if (d.current_work_area_)
341 d.current_work_area_->setFocus();
347 QMenu* GuiView::createPopupMenu()
349 return d.toolBarPopup(this);
355 // GuiToolbars *must* be initialised before GuiMenubar.
356 d.toolbars_ = new GuiToolbars(*this);
357 // FIXME: GuiToolbars::init() cannot be integrated in the ctor
358 // because LyXFunc::getStatus() needs a properly initialized
359 // GuiToolbars object (for LFUN_TOOLBAR_TOGGLE).
361 d.menubar_ = new GuiMenubar(this, menubackend);
363 statusBar()->setSizeGripEnabled(true);
365 QObject::connect(&statusbar_timer_, SIGNAL(timeout()),
366 this, SLOT(clearMessage()));
372 void GuiView::showEvent(QShowEvent * e)
374 if (lyxrc.allow_geometry_session) {
376 QString const key = "view-" + QString::number(id());
377 if (!restoreGeometry(settings.value(key + "/geometry").toByteArray()))
378 setGeometry(50, 50, 690, 510);
379 setIconSize(settings.value(key + "/icon_size").toSize());
381 setGeometry(50, 50, 690, 510);
383 if (d.splitter_->count() == 0)
384 // No work area, switch to the background widget.
387 QMainWindow::showEvent(e);
391 void GuiView::closeEvent(QCloseEvent * close_event)
393 // we may have been called through the close window button
394 // which bypasses the LFUN machinery.
395 if (!quitting_by_menu_ && theApp()->gui().viewIds().size() == 1) {
396 if (!theBufferList().quitWriteAll()) {
397 close_event->ignore();
402 // Make sure that no LFUN use this close to be closed View.
403 theLyXFunc().setLyXView(0);
404 // Make sure the timer time out will not trigger a statusbar update.
405 statusbar_timer_.stop();
407 if (lyxrc.allow_geometry_session) {
409 QString const key = "view-" + QString::number(id());
410 settings.setValue(key + "/geometry", saveGeometry());
411 settings.setValue(key + "/icon_size", iconSize());
412 d.toolbars_->saveToolbarInfo();
415 theApp()->gui().unregisterView(id());
416 if (!theApp()->gui().viewIds().empty()) {
417 // Just close the window and do nothing else if this is not the
419 close_event->accept();
425 // this is the place where we leave the frontend.
426 // it is the only point at which we start quitting.
427 close_event->accept();
428 // quit the event loop
433 void GuiView::dragEnterEvent(QDragEnterEvent * event)
435 if (event->mimeData()->hasUrls())
437 /// \todo Ask lyx-devel is this is enough:
438 /// if (event->mimeData()->hasFormat("text/plain"))
439 /// event->acceptProposedAction();
443 void GuiView::dropEvent(QDropEvent* event)
445 QList<QUrl> files = event->mimeData()->urls();
449 LYXERR(Debug::GUI) << BOOST_CURRENT_FUNCTION
450 << " got URLs!" << endl;
451 for (int i = 0; i != files.size(); ++i) {
452 string const file = support::os::internal_path(fromqstr(
453 files.at(i).toLocalFile()));
455 dispatch(FuncRequest(LFUN_FILE_OPEN, file));
460 void GuiView::message(docstring const & str)
462 statusBar()->showMessage(toqstr(str));
463 statusbar_timer_.stop();
464 statusbar_timer_.start(statusbar_timer_value);
468 void GuiView::smallSizedIcons()
470 setIconSize(QSize(d.smallIconSize, d.smallIconSize));
474 void GuiView::normalSizedIcons()
476 setIconSize(QSize(d.normalIconSize, d.normalIconSize));
480 void GuiView::bigSizedIcons()
482 setIconSize(QSize(d.bigIconSize, d.bigIconSize));
486 void GuiView::clearMessage()
490 theLyXFunc().setLyXView(this);
491 statusBar()->showMessage(toqstr(theLyXFunc().viewStatusMessage()));
492 statusbar_timer_.stop();
496 void GuiView::updateWindowTitle(GuiWorkArea * wa)
498 if (wa != d.current_work_area_)
500 setWindowTitle(qt_("LyX: ") + wa->windowTitle());
501 setWindowIconText(wa->windowIconText());
505 void GuiView::on_currentWorkAreaChanged(GuiWorkArea * wa)
508 disconnectBufferView();
509 connectBufferView(wa->bufferView());
510 connectBuffer(wa->bufferView().buffer());
511 d.current_work_area_ = wa;
512 QObject::connect(wa, SIGNAL(titleChanged(GuiWorkArea *)),
513 this, SLOT(updateWindowTitle(GuiWorkArea *)));
514 updateWindowTitle(wa);
517 // Buffer-dependent dialogs should be updated or
518 // hidden. This should go here because some dialogs (eg ToC)
519 // require bv_->text.
520 dialogs_->updateBufferDependent(true);
522 updateLayoutChoice(false);
527 void GuiView::updateStatusBar()
529 // let the user see the explicit message
530 if (statusbar_timer_.isActive())
533 statusBar()->showMessage(toqstr(theLyXFunc().viewStatusMessage()));
537 bool GuiView::hasFocus() const
539 return qApp->activeWindow() == this;
543 bool GuiView::event(QEvent * e)
547 // Useful debug code:
548 //case QEvent::ActivationChange:
549 //case QEvent::WindowDeactivate:
550 //case QEvent::Paint:
551 //case QEvent::Enter:
552 //case QEvent::Leave:
553 //case QEvent::HoverEnter:
554 //case QEvent::HoverLeave:
555 //case QEvent::HoverMove:
556 //case QEvent::StatusTip:
557 //case QEvent::DragEnter:
558 //case QEvent::DragLeave:
562 case QEvent::WindowActivate: {
563 theApp()->setCurrentView(*this);
564 if (d.current_work_area_) {
565 BufferView & bv = d.current_work_area_->bufferView();
566 connectBufferView(bv);
567 connectBuffer(bv.buffer());
568 // The document structure, name and dialogs might have
569 // changed in another view.
570 dialogs_->updateBufferDependent(true);
572 setWindowTitle(qt_("LyX"));
573 setWindowIconText(qt_("LyX"));
575 return QMainWindow::event(e);
577 case QEvent::ShortcutOverride: {
578 QKeyEvent * ke = static_cast<QKeyEvent*>(e);
579 if (!d.current_work_area_) {
580 theLyXFunc().setLyXView(this);
582 setKeySymbol(&sym, ke);
583 theLyXFunc().processKeySym(sym, q_key_state(ke->modifiers()));
587 if (ke->key() == Qt::Key_Tab || ke->key() == Qt::Key_Backtab) {
589 setKeySymbol(&sym, ke);
590 d.current_work_area_->processKeySym(sym, NoModifier);
596 return QMainWindow::event(e);
601 bool GuiView::focusNextPrevChild(bool /*next*/)
608 void GuiView::setBusy(bool yes)
610 if (d.current_work_area_) {
611 d.current_work_area_->setUpdatesEnabled(!yes);
613 d.current_work_area_->stopBlinkingCursor();
615 d.current_work_area_->startBlinkingCursor();
619 QApplication::setOverrideCursor(Qt::WaitCursor);
621 QApplication::restoreOverrideCursor();
625 GuiToolbar * GuiView::makeToolbar(ToolbarInfo const & tbinfo, bool newline)
627 GuiToolbar * toolBar = new GuiToolbar(tbinfo, *this);
629 if (tbinfo.flags & ToolbarInfo::TOP) {
631 addToolBarBreak(Qt::TopToolBarArea);
632 addToolBar(Qt::TopToolBarArea, toolBar);
635 if (tbinfo.flags & ToolbarInfo::BOTTOM) {
636 // Qt < 4.2.2 cannot handle ToolBarBreak on non-TOP dock.
637 #if (QT_VERSION >= 0x040202)
639 addToolBarBreak(Qt::BottomToolBarArea);
641 addToolBar(Qt::BottomToolBarArea, toolBar);
644 if (tbinfo.flags & ToolbarInfo::LEFT) {
645 // Qt < 4.2.2 cannot handle ToolBarBreak on non-TOP dock.
646 #if (QT_VERSION >= 0x040202)
648 addToolBarBreak(Qt::LeftToolBarArea);
650 addToolBar(Qt::LeftToolBarArea, toolBar);
653 if (tbinfo.flags & ToolbarInfo::RIGHT) {
654 // Qt < 4.2.2 cannot handle ToolBarBreak on non-TOP dock.
655 #if (QT_VERSION >= 0x040202)
657 addToolBarBreak(Qt::RightToolBarArea);
659 addToolBar(Qt::RightToolBarArea, toolBar);
662 // The following does not work so I cannot restore to exact toolbar location
664 ToolbarSection::ToolbarInfo & tbinfo = LyX::ref().session().toolbars().load(tbinfo.name);
665 toolBar->move(tbinfo.posx, tbinfo.posy);
672 GuiWorkArea * GuiView::workArea(Buffer & buffer)
674 for (int i = 0; i != d.splitter_->count(); ++i) {
675 GuiWorkArea * wa = d.tabWorkArea(i)->workArea(buffer);
683 GuiWorkArea * GuiView::addWorkArea(Buffer & buffer)
685 GuiWorkArea * wa = new GuiWorkArea(buffer, *this);
686 wa->setUpdatesEnabled(false);
688 // Automatically create a TabWorkArea if there are none yet.
689 if (!d.splitter_->count())
692 TabWorkArea * tab_widget = d.currentTabWorkArea();
693 tab_widget->addTab(wa, wa->windowTitle());
694 QObject::connect(wa, SIGNAL(titleChanged(GuiWorkArea *)),
695 tab_widget, SLOT(updateTabText(GuiWorkArea *)));
697 wa->bufferView().updateMetrics();
699 // Hide tabbar if there's only one tab.
700 tab_widget->showBar(tab_widget->count() > 1);
705 void GuiView::addTabWorkArea()
707 TabWorkArea * twa = new TabWorkArea;
708 QObject::connect(twa, SIGNAL(currentWorkAreaChanged(GuiWorkArea *)),
709 this, SLOT(on_currentWorkAreaChanged(GuiWorkArea *)));
710 d.splitter_->addWidget(twa);
711 d.stack_widget_->setCurrentWidget(d.splitter_);
715 GuiWorkArea const * GuiView::currentWorkArea() const
717 return d.current_work_area_;
721 void GuiView::setCurrentWorkArea(GuiWorkArea * work_area)
723 BOOST_ASSERT(work_area);
725 // Changing work area can result from opening a file so
726 // update the toc in any case.
729 GuiWorkArea * wa = static_cast<GuiWorkArea *>(work_area);
730 d.current_work_area_ = wa;
731 for (int i = 0; i != d.splitter_->count(); ++i) {
732 if (d.tabWorkArea(i)->setCurrentWorkArea(wa))
738 void GuiView::removeWorkArea(GuiWorkArea * work_area)
740 BOOST_ASSERT(work_area);
741 GuiWorkArea * gwa = static_cast<GuiWorkArea *>(work_area);
742 if (gwa == d.current_work_area_) {
744 disconnectBufferView();
745 dialogs_->hideBufferDependent();
746 d.current_work_area_ = 0;
749 // removing a work area often results from closing a file so
750 // update the toc in any case.
753 for (int i = 0; i != d.splitter_->count(); ++i) {
754 TabWorkArea * twa = d.tabWorkArea(i);
755 if (!twa->removeWorkArea(gwa))
756 // Not found in this tab group.
759 // We found and removed the GuiWorkArea.
761 // No more WorkAreas in this tab group, so delete it.
766 if (d.current_work_area_)
767 // This means that we are not closing the current GuiWorkArea;
770 // Switch to the next GuiWorkArea in the found TabWorkArea.
771 d.current_work_area_ = twa->currentWorkArea();
775 if (d.splitter_->count() == 0)
776 // No more work area, switch to the background widget.
781 void GuiView::updateLayoutChoice(bool force)
783 // Don't show any layouts without a buffer
785 d.toolbars_->clearLayoutList();
789 // Update the layout display
790 if (d.toolbars_->updateLayoutList(buffer()->params().getTextClassPtr(), force)) {
791 d.current_layout = buffer()->params().getTextClass().defaultLayoutName();
794 docstring const & layout = d.current_work_area_->bufferView().cursor().
795 innerParagraph().layout()->name();
797 if (layout != d.current_layout) {
798 d.toolbars_->setLayout(layout);
799 d.current_layout = layout;
804 bool GuiView::isToolbarVisible(std::string const & id)
806 return d.toolbars_->visible(id);
809 void GuiView::updateToolbars()
811 if (d.current_work_area_) {
813 d.current_work_area_->bufferView().cursor().inMathed();
815 lyx::getStatus(FuncRequest(LFUN_LAYOUT_TABULAR)).enabled();
817 lyx::getStatus(FuncRequest(LFUN_CHANGES_TRACK)).enabled() &&
818 lyx::getStatus(FuncRequest(LFUN_CHANGES_TRACK)).onoff(true);
820 d.toolbars_->update(math, table, review);
822 d.toolbars_->update(false, false, false);
824 // update read-only status of open dialogs.
825 dialogs_->checkStatus();
829 Buffer * GuiView::buffer()
831 if (d.current_work_area_)
832 return &d.current_work_area_->bufferView().buffer();
837 Buffer const * GuiView::buffer() const
839 if (d.current_work_area_)
840 return &d.current_work_area_->bufferView().buffer();
845 void GuiView::setBuffer(Buffer * newBuffer)
847 BOOST_ASSERT(newBuffer);
850 GuiWorkArea * wa = workArea(*newBuffer);
852 updateLabels(*newBuffer->masterBuffer());
853 wa = addWorkArea(*newBuffer);
855 //Disconnect the old buffer...there's no new one.
858 connectBuffer(*newBuffer);
859 connectBufferView(wa->bufferView());
860 setCurrentWorkArea(wa);
866 Buffer * GuiView::loadLyXFile(FileName const & filename, bool tolastfiles)
870 Buffer * newBuffer = checkAndLoadLyXFile(filename);
873 message(_("Document not loaded."));
879 GuiWorkArea * wa = workArea(*newBuffer);
881 wa = addWorkArea(*newBuffer);
883 // scroll to the position when the file was last closed
884 if (lyxrc.use_lastfilepos) {
885 LastFilePosSection::FilePos filepos =
886 LyX::ref().session().lastFilePos().load(filename);
887 // if successfully move to pit (returned par_id is not zero),
888 // update metrics and reset font
889 wa->bufferView().moveToPosition(filepos.pit, filepos.pos, 0, 0);
893 LyX::ref().session().lastFiles().add(filename);
900 void GuiView::connectBuffer(Buffer & buf)
902 buf.setGuiDelegate(this);
906 void GuiView::disconnectBuffer()
908 if (d.current_work_area_)
909 d.current_work_area_->bufferView().setGuiDelegate(0);
913 void GuiView::connectBufferView(BufferView & bv)
915 bv.setGuiDelegate(this);
919 void GuiView::disconnectBufferView()
921 if (d.current_work_area_)
922 d.current_work_area_->bufferView().setGuiDelegate(0);
926 void GuiView::errors(string const & error_type)
928 ErrorList & el = buffer()->errorList(error_type);
930 dialogs_->show("errorlist", error_type);
934 void GuiView::showDialog(string const & name)
936 dialogs_->show(name);
940 void GuiView::showDialogWithData(string const & name, string const & data)
942 dialogs_->show(name, data);
946 void GuiView::showInsetDialog(string const & name, string const & data,
949 dialogs_->show(name, data, inset);
953 void GuiView::updateDialog(string const & name, string const & data)
955 if (dialogs_->visible(name))
956 dialogs_->update(name, data);
960 BufferView * GuiView::view()
962 return d.current_work_area_ ? &d.current_work_area_->bufferView() : 0;
966 void GuiView::updateToc()
968 updateDialog("toc", "");
972 void GuiView::updateEmbeddedFiles()
974 updateDialog("embedding", "");
978 void GuiView::autoSave()
980 LYXERR(Debug::INFO) << "Running autoSave()" << endl;
983 view()->buffer().autoSave();
987 void GuiView::resetAutosaveTimers()
990 autosave_timeout_->restart();
994 void GuiView::dispatch(FuncRequest const & cmd)
997 case LFUN_BUFFER_SWITCH:
998 setBuffer(theBufferList().getBuffer(to_utf8(cmd.argument())));
1001 case LFUN_COMMAND_EXECUTE: {
1002 bool const show_it = cmd.argument() != "off";
1003 d.toolbars_->showCommandBuffer(show_it);
1006 case LFUN_DROP_LAYOUTS_CHOICE:
1007 d.toolbars_->openLayoutList();
1010 case LFUN_MENU_OPEN:
1011 d.menubar_->openByName(toqstr(cmd.argument()));
1014 case LFUN_TOOLBAR_TOGGLE: {
1015 string const name = cmd.getArg(0);
1016 bool const allowauto = cmd.getArg(1) == "allowauto";
1017 // it is possible to get current toolbar status like this,...
1018 // but I decide to obey the order of ToolbarBackend::flags
1019 // and disregard real toolbar status.
1020 // toolbars_->saveToolbarInfo();
1022 // toggle state on/off/auto
1023 d.toolbars_->toggleToolbarState(name, allowauto);
1027 ToolbarInfo * tbi = d.toolbars_->getToolbarInfo(name);
1029 message(bformat(_("Unknown toolbar \"%1$s\""), from_utf8(name)));
1033 if (tbi->flags & ToolbarInfo::ON)
1035 else if (tbi->flags & ToolbarInfo::OFF)
1037 else if (tbi->flags & ToolbarInfo::AUTO)
1040 message(bformat(_("Toolbar \"%1$s\" state set to %2$s"),
1041 _(tbi->gui_name), state));
1046 theLyXFunc().setLyXView(this);
1052 Buffer const * GuiView::updateInset(Inset const * inset)
1054 if (!d.current_work_area_)
1058 d.current_work_area_->scheduleRedraw();
1060 return &d.current_work_area_->bufferView().buffer();
1064 void GuiView::restartCursor()
1066 /* When we move around, or type, it's nice to be able to see
1067 * the cursor immediately after the keypress.
1069 if (d.current_work_area_)
1070 d.current_work_area_->startBlinkingCursor();
1073 } // namespace frontend
1076 #include "GuiView_moc.cpp"