/usr/include/KF5/KParts/kparts/mainwindow.h is in libkf5parts-dev 5.28.0-1.
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 112 113 114 115 116 117 118 | /* This file is part of the KDE project
Copyright (C) 1999 Simon Hausmann <hausmann@kde.org>
(C) 1999 David Faure <faure@kde.org>
This library 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 library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#ifndef __MAINWINDOW_H
#define __MAINWINDOW_H
#include <kparts/part.h>
#include <kxmlguiwindow.h>
class QString;
namespace KParts
{
class MainWindowPrivate;
/**
* A KPart-aware main window, whose user interface is described in XML.
*
* It implements all internal interfaces in the case of a
* KMainWindow as host: the builder and servant interface (for menu
* merging).
*
* Inherit your main window from this class
* and don't forget to call setupGUI() before you call createGUI()
* on the KPart. For example:
*
* \code
* setCentralWidget(m_part->widget());
* setupGUI(ToolBar | Keys | StatusBar | Save, "appui.rc");
* createGUI(m_part);
* \endcode
*
* @warning you should not pass the Default flag to setupGUI(), since it contains
* the Create flag that is not supposed to be used from this class.
* @see setupGUI, @see createGUI
*
*/
class KPARTS_EXPORT MainWindow : public KXmlGuiWindow, virtual public PartBase
{
Q_OBJECT
public:
/**
* Constructor, same signature as KMainWindow.
*/
explicit MainWindow(QWidget *parent = 0, Qt::WindowFlags f = KDE_DEFAULT_WINDOWFLAGS);
/**
* Destructor.
*/
virtual ~MainWindow();
public Q_SLOTS:
void configureToolbars() Q_DECL_OVERRIDE;
protected Q_SLOTS:
/**
* Create the GUI (by merging the host's and the active part's)
* You _must_ call this in order to see any GUI being created.
*
* In a main window with multiple parts being shown (e.g. as in Konqueror)
* you need to connect this slot to the
* KPartManager::activePartChanged() signal
*
* @param part The active part (set to 0L if no part).
*/
void createGUI(KParts::Part *part);
/**
* Enable or disable the automatic setting of window titles by the part's document title.
* By default, a part always changes the window title when the document changes.
* @note This value must be set before calling @see createGUI.
*
* @param enabled boolean to enable or disable the window title handling
* @since 5.24
*/
void setWindowTitleHandling(bool enabled);
/**
* Called when the active part wants to change the statusbar message
* Reimplement if your mainwindow has a complex statusbar
* (with several items)
*/
virtual void slotSetStatusBarText(const QString &);
/**
* Rebuilds the GUI after KEditToolbar changed the toolbar layout.
* @see configureToolbars()
*/
void saveNewToolbarConfig() Q_DECL_OVERRIDE;
protected:
virtual void createShellGUI(bool create = true);
private:
MainWindowPrivate *const d;
};
}
#endif
|