/usr/include/ktexteditor/editor.h is in kdelibs5-dev 4:4.8.5-0ubuntu0.6.
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 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 | /* This file is part of the KDE libraries
* Copyright (C) 2005 Christoph Cullmann <cullmann@kde.org>
* Copyright (C) 2005 Dominik Haumann (dhdev@gmx.de) (documentation)
*
* 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 KDELIBS_KTEXTEDITOR_EDITOR_H
#define KDELIBS_KTEXTEDITOR_EDITOR_H
#include <ktexteditor/ktexteditor_export.h>
// our main baseclass of the KTextEditor::Editor
#include <QtCore/QObject>
#include <kicon.h>
class KAboutData;
class KConfig;
namespace KTextEditor
{
class Document;
class ConfigPage;
/**
* \brief Accessor interface for Editor part.
*
* Topics:
* - \ref editor_intro
* - \ref editor_config
* - \ref editor_notes
* - \ref editor_extensions
*
* \section editor_intro Introduction
*
* The Editor part can be accessed via the KTextEditor::Factory or the
* KTextEditor::EditorChooser and provides
* general information and configuration methods for the Editor
* implementation, for example KAboutData by using aboutData().
*
* The Editor implementation has a list of all opened documents. Get this
* list with documents(). To create a new Document call createDocument(). The
* signal documentCreated() is emitted whenever the Editor created a new
* document.
*
* \section editor_config Editor Configuration
*
* If the Editor implementation supports a config dialog
* configDialogSupported() returns \e true, then the config dialog can be
* shown with configDialog(). Instead of using the config dialog, the config
* pages can be embedded into the application's config dialog. To do this,
* configPages() returns the number of
* config pages the Editor implementation provides and configPage() returns
* the requested page. Further, a config page has a short descriptive name,
* get it with configPageName(). You can get more detailed name by using
* configPageFullName(). Also every config page has a pixmap, get it with
* configPagePixmap(). The configuration can be saved and loaded with
* readConfig() and writeConfig().
*
* \note We recommend to embedd the config pages into the main application's
* config dialog instead of using a separate config dialog, if the config
* dialog does not look cluttered then. This way, all settings are grouped
* together in one place.
*
* \section editor_notes Implementation Notes
*
* Usually only one instance of the Editor exists. The Kate Part
* implementation internally uses a static accessor to make sure that only one
* Kate Part Editor object exists. So several factories still use the same
* Editor.
*
* readConfig() and writeConfig() should be forwarded to all loaded plugins
* as well, see KTextEditor::Plugin::readConfig() and
* KTextEditor::Plugin::writeConfig().
*
* \section editor_extensions Editor Extension Interfaces
*
* There is only a single extension interface for the Editor: the
* CommandInterface. With the CommandInterface it is possible to add and
* remove new command line commands which are valid for all documents. Common
* use cases are for example commands like \e find or setting document
* variables. For further details read the detailed descriptions in the class
* KTextEditor::CommandInterface.
*
* \see KTextEditor::Factory, KTextEditor::Document, KTextEditor::ConfigPage
* KTextEditor::Plugin, KTextEditor::CommandInterface
* \author Christoph Cullmann \<cullmann@kde.org\>
*/
class KTEXTEDITOR_EXPORT Editor : public QObject
{
Q_OBJECT
public:
/**
* Constructor.
*
* Create the Editor object with \p parent.
* \param parent parent object
*/
Editor ( QObject *parent );
/**
* Virtual destructor.
*/
virtual ~Editor ();
/**
* Switch editor to simple mode for average users
*/
public:
/**
* Switch the editor to a simple mode which will hide advanced
* stuff from average user or switch it back to normal mode.
* This mode will only affect documents/views created after the
* change.
* \param on turn simple mode on or not
*/
void setSimpleMode (bool on);
/**
* Query the editor whether simple mode is on or not.
* \return \e true if simple mode is on, otherwise \e false
* \see setSimpleMode()
*/
bool simpleMode () const;
/*
* Methods to create and manage the documents.
*/
public:
/**
* Create a new document object with \p parent.
* \param parent parent object
* \return new KTextEditor::Document object
* \see documents()
*/
virtual Document *createDocument ( QObject *parent ) = 0;
/**
* Get a list of all documents of this editor.
* \return list of all existing documents
* \see createDocument()
*/
virtual const QList<Document*> &documents () = 0;
/*
* General Information about this editor.
*/
public:
/**
* Get the about data of this Editor part.
* \return about data
*/
virtual const KAboutData *aboutData () const = 0;
/**
* Get the current default encoding for this Editor part.
* \return default encoding
* \since 4.5
*/
const QString &defaultEncoding () const;
protected:
/**
* Set the current default encoding for this Editor part.
* Editor part implementation should call this internally on creation and config changes.
* \param defaultEncoding new default encoding
* \since 4.5
*/
void setDefaultEncoding (const QString &defaultEncoding);
/*
* Configuration management.
*/
public:
/**
* Read editor configuration from KConfig \p config.
*
* \note Implementation Notes: If \p config is NULL you should use
* kapp->config() as a fallback solution. Additionally the
* readConfig() call should be forwarded to every loaded plugin.
* \param config config object
* \see writeConfig()
*/
virtual void readConfig (KConfig *config = 0) = 0;
/**
* Write editor configuration to KConfig \p config.
*
* \note Implementation Notes: If \p config is NULL you should use
* kapp->config() as a fallback solution. Additionally the
* writeConfig() call should be forwarded to every loaded plugin.
* \param config config object
* \see readConfig()
*/
virtual void writeConfig (KConfig *config = 0) = 0;
/**
* Check, whether this editor has a configuration dialog.
* \return \e true, if the editor has a configuration dialog,
* otherwise \e false
* \see configDialog()
*/
virtual bool configDialogSupported () const = 0;
/**
* Show the editor's config dialog, changes will be applied to the
* editor, but not saved anywhere automagically, call \p writeConfig()
* to save them.
*
* \note Instead of using the config dialog, the config pages can be
* embedded into your own config dialog by using configPages() and
* configPage().
* \param parent parent widget
* \see configDialogSupported()
*/
virtual void configDialog (QWidget *parent) = 0;
/**
* Get the number of available config pages.
* If the editor returns a number < 1, it does not support config pages
* and the embedding application should use configDialog() instead.
* \return number of config pages
* \see configPage(), configDialog()
*/
virtual int configPages () const = 0;
/**
* Get the config page with the \p number, config pages from 0 to
* configPages()-1 are available if configPages() > 0.
* \param number index of config page
* \param parent parent widget for config page
* \return created config page or NULL, if the number is out of bounds
* \see configPages()
*/
virtual ConfigPage *configPage (int number, QWidget *parent) = 0;
/**
* Get a readable name for the config page \p number. The name should be
* translated.
* \param number index of config page
* \return name of given page index
* \see configPageFullName(), configPagePixmap()
*/
virtual QString configPageName (int number) const = 0;
/**
* Get a readable full name for the config page \e number. The name
* should be translated.
*
* Example: If the name is "Filetypes", the full name could be
* "Filetype Specific Settings". For "Shortcuts" the full name would be
* something like "Shortcut Configuration".
* \param number index of config page
* \return full name of given page index
* \see configPageName(), configPagePixmap()
*/
virtual QString configPageFullName (int number) const = 0;
/**
* Get a pixmap with \p size for the config page \p number.
* \param number index of config page
* \return pixmap for the given page index
* \see configPageName(), configPageFullName()
*/
virtual KIcon configPageIcon (int number) const = 0;
Q_SIGNALS:
/**
* The \p editor emits this signal whenever a \p document was successfully
* created.
* \param editor editor which created the new document
* \param document the newly created document instance
* \see createDocument()
*/
void documentCreated (KTextEditor::Editor *editor,
KTextEditor::Document *document);
private:
class EditorPrivate* const d;
};
/**
* Helper function for the EditorChooser.
* Usually you do not have to use this function. Instead, use
* KTextEditor::EditorChooser::editor().
* \param libname library name, for example "katepart"
* \return the Editor object on success, otherwise NULL
* \see KTextEditor::EditorChooser::editor()
*/
KTEXTEDITOR_EXPORT Editor *editor ( const char *libname );
}
#endif
// kate: space-indent on; indent-width 2; replace-tabs on;
|