/usr/include/kdevplatform/sublime/view.h is in libsublime-dev 1.7.3-0ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | /***************************************************************************
* Copyright 2006-2007 Alexander Dymo <adymo@kdevelop.org> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU Library General Public License as *
* published by the Free Software Foundation; either version 2 of the *
* License, or (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. *
***************************************************************************/
#ifndef KDEVPLATFORM_SUBLIMEVIEW_H
#define KDEVPLATFORM_SUBLIMEVIEW_H
#include <QtCore/QObject>
#include <QtCore/QMetaType>
#include "sublimeexport.h"
class QAction;
namespace Sublime {
class Document;
/**
@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 SUBLIME_EXPORT View: public QObject {
Q_OBJECT
public:
enum WidgetOwnership {
TakeOwnership,
DoNotTakeOwnerShip
};
~View();
/**@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 = 0);
/**@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;
/// Retrieve view state for saving into configuration.
virtual QString viewState() const;
/// Restore view state from configuration
virtual void setState(const QString& state);
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:
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:
Q_PRIVATE_SLOT(d, void unsetWidget())
//copy is not allowed, create a new view from the document instead
View(const View &v);
struct ViewPrivate *const d;
friend class Document;
};
}
Q_DECLARE_METATYPE(Sublime::View*)
#endif
|