1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
|
/*
SPDX-FileCopyrightText: 2006-2007 Alexander Dymo <adymo@kdevelop.org>
SPDX-License-Identifier: LGPL-2.0-or-later
*/
#ifndef KDEVPLATFORM_SUBLIMEVIEW_H
#define KDEVPLATFORM_SUBLIMEVIEW_H
#include <QObject>
#include <QMetaType>
#include "sublimeexport.h"
class KConfigGroup;
class QAction;
namespace Sublime {
class Document;
class ViewPrivate;
/**
@short View - the wrapper to the widget that knows about its document
Views are the convenient way to manage a widget. It is specifically designed to be
light and fast. Use @ref Document::createView() to get the new view for the document
and call @ref View::widget() to create and get the actual widget.
It is not possible to create a view by hand. You need either subclass it or use a Document.
If you create a subclass of View you need to override Sublime::View::createWidget to
provide a custom widget for your view.
*/
class KDEVPLATFORMSUBLIME_EXPORT View: public QObject {
Q_OBJECT
public:
enum WidgetOwnership {
TakeOwnership,
DoNotTakeOwnerShip
};
~View() override;
/**@return the toolbar actions for this view, this needs to be called _after_ the first call to widget() */
QList<QAction*> toolBarActions() const;
/**@return the toolbar actions for this view, this needs to be called _after_ the first call to widget() */
QList<QAction*> contextMenuActions() const;
/**@return the document for this view.*/
Document *document() const;
/**@return widget for this view (creates it if it's not yet created).*/
QWidget *widget(QWidget *parent = nullptr);
/**@return true if this view has an initialized widget.*/
bool hasWidget() const;
/// Retrieve information to be placed in the status bar.
virtual QString viewStatus() const;
/**
* Read session settings from the given \p config.
*
* The default implementation is a no-op
*
* @see KTextEditor::View::readSessionConfig()
*/
virtual void readSessionConfig(KConfigGroup &config);
/**
* Write session settings to the \p config.
*
* The default implementation is a no-op
*
* @see KTextEditor::View::writeSessionConfig()
*/
virtual void writeSessionConfig(KConfigGroup &config);
void notifyPositionChanged(int newPositionInArea);
Q_SIGNALS:
void raise(Sublime::View*);
/// Notify that the status for this document has changed
void statusChanged(Sublime::View*);
void positionChanged(Sublime::View*, int);
public Q_SLOTS:
void requestRaise();
protected:
explicit View(Document *doc, WidgetOwnership ws = DoNotTakeOwnerShip );
/**
* override this function to create a custom widget in your View subclass
* @param parent the parent widget
* @returns a new widget which is used for this view
*/
virtual QWidget *createWidget(QWidget *parent);
private:
//copy is not allowed, create a new view from the document instead
View(const View &v);
const QScopedPointer<class ViewPrivate> d_ptr;
Q_DECLARE_PRIVATE(View)
friend class Document;
};
}
#endif
|