3 * \file GuiViewSource.h
4 * This file is part of LyX, the document processor.
5 * Licence details can be found in the file COPYING.
9 * \author Abdelrazak Younes
11 * Full author contact details are available in file CREDITS.
14 #ifndef GUIVIEWSOURCE_H
15 #define GUIVIEWSOURCE_H
17 #include "ui_ViewSourceUi.h"
21 #include "qt_helpers.h"
23 #include <QDockWidget>
25 #include <QTextCharFormat>
33 class LaTeXHighlighter;
35 class ViewSourceWidget : public QWidget, public Ui::ViewSourceUi
40 ViewSourceWidget(GuiViewSource &);
48 GuiViewSource & controller_;
50 QTextDocument * document_;
51 /// LaTeX syntax highlighter
52 LaTeXHighlighter * highlighter_;
56 class GuiViewSource : public DockView
62 GuiView & parent, ///< the main window where to dock.
63 Qt::DockWidgetArea area = Qt::BottomDockWidgetArea, ///< Position of the dock (and also drawer)
64 Qt::WindowFlags flags = 0);
68 /// Controller inherited method.
70 bool initialiseParams(std::string const & source);
72 void dispatchParams() {}
73 bool isBufferDependent() const { return true; }
74 bool canApply() const { return true; }
75 bool canApplyToReadOnly() const { return true; }
77 void enableView(bool enable);
78 void saveSession() const;
79 void restoreSession();
80 bool wantInitialFocus() const { return false; }
83 /// The title displayed by the dialog reflects source type.
84 QString title() const;
86 /** get the source code of selected paragraphs, or the whole document
87 \param fullSource get full source code
89 QString getContent(bool fullSource);
90 // cursor position in the source code
91 struct Row { int begin; int end; };
95 /// The encapsulated widget.
96 ViewSourceWidget * widget_;
99 } // namespace frontend
102 #endif // GUIVIEWSOURCE_H