2 * \file GuiApplication.h
3 * This file is part of LyX, the document processor.
4 * Licence details can be found in the file COPYING.
8 * \author Abdelrazak Younes
10 * Full author contact details are available in file CREDITS.
13 #ifndef GUIAPPLICATION_H
14 #define GUIAPPLICATION_H
16 #include "ColorCache.h"
17 #include "FontLoader.h"
18 #include "GuiClipboard.h"
19 #include "GuiSelection.h"
22 #include "frontends/Application.h"
25 #include <QApplication>
27 #include <QTranslator>
32 class QSessionManager;
46 /// The Qt main application class
48 There should be only one instance of this class. No Qt object
49 initialisation should be done before the instanciation of this class.
51 class GuiApplication : public QApplication, public Application
56 GuiApplication(int & argc, char ** argv);
58 virtual ~GuiApplication();
60 /// Method inherited from \c Application class
62 virtual FuncStatus getStatus(FuncRequest const &);
63 virtual bool dispatch(FuncRequest const &);
64 virtual void resetGui();
65 void restoreGuiSession();
66 virtual Clipboard & clipboard();
67 virtual Selection & selection();
68 virtual FontLoader & fontLoader() { return font_loader_; }
70 virtual void exit(int status);
71 virtual bool event(QEvent * e);
72 virtual bool getRgbColor(ColorCode col, RGBColor & rgbcol);
73 virtual std::string const hexName(ColorCode col);
74 virtual void updateColor(ColorCode col);
75 virtual void readMenus(Lexer & lex);
76 virtual void initGlobalMenu();
77 virtual void registerSocketCallback(int fd, SocketCallback func);
78 void unregisterSocketCallback(int fd);
79 bool searchMenu(FuncRequest const & func, std::vector<docstring> & names) const;
82 Menus const & menus() const { return menus_; }
83 Menus & menus() { return menus_; }
84 /// Methods inherited from \c QApplication class
86 bool notify(QObject * receiver, QEvent * event);
87 void commitData(QSessionManager & sm);
90 /// Create the main window with given geometry settings.
91 /// \param geometry_arg: only for Windows platform.
92 void createView(QString const & geometry_arg = QString(),
93 bool autoShow = true);
95 GuiView const * currentView() const { return current_view_; }
97 GuiView * currentView() { return current_view_; }
99 void setCurrentView(GuiView * view) { current_view_ = view; }
101 virtual size_t viewCount() const { return view_ids_.size(); }
103 std::vector<int> const & viewIds() { return view_ids_; }
106 ColorCache & colorCache() { return color_cache_; }
108 /// return a suitable serif font name.
109 virtual QString const romanFontName();
111 /// return a suitable sans serif font name.
112 virtual QString const sansFontName();
114 /// return a suitable monospaced font name.
115 virtual QString const typewriterFontName();
117 virtual bool unregisterView(int id);
119 virtual GuiView & view(int id) const;
121 virtual void hideDialogs(std::string const & name, Inset * inset) const;
123 virtual Buffer const * updateInset(Inset const * inset) const;
127 void execBatchCommands();
129 void socketDataReceived(int fd);
130 /// events to be triggered by general_timer_ should go here
131 void handleRegularEvents();
133 void onLastWindowClosed();
137 bool closeAllViews();
139 GuiClipboard clipboard_;
141 GuiSelection selection_;
143 FontLoader font_loader_;
145 ColorCache color_cache_;
147 QTranslator qt_trans_;
149 std::map<int, SocketNotifier *> socket_notifiers_;
152 /// this timer is used for any regular events one wants to
153 /// perform. at present it is used to check if forked processes
155 QTimer general_timer_;
159 bool x11EventFilter(XEvent * ev);
161 /// A translator suitable for the entries in the LyX menu.
162 /// Only needed with Qt/Mac.
163 void addMenuTranslator();
165 /// Multiple views container.
167 * Warning: This must not be a smart pointer as the destruction of the
168 * object is handled by Qt when the view is closed
169 * \sa Qt::WA_DeleteOnClose attribute.
171 std::map<int, GuiView *> views_;
173 std::vector<int> view_ids_;
174 /// This LyXView is the one receiving Clipboard and Selection
176 GuiView * current_view_;
178 GlobalMenuBar * global_menubar_;
181 extern GuiApplication * guiApp;
183 } // namespace frontend
186 #endif // GUIAPPLICATION_H