/usr/include/ktexteditor/configinterface.h is in kdelibs5-dev 4:4.14.2-5+deb8u2.
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 | /* This file is part of the KDE project
Copyright (C) 2006 Matt Broadstone (mbroadst@gmail.com)
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_CONFIGINTERFACE_H
#define KDELIBS_KTEXTEDITOR_CONFIGINTERFACE_H
#include <ktexteditor/ktexteditor_export.h>
#include <QtCore/QStringList>
#include <QtCore/QVariant>
namespace KTextEditor
{
/**
* \brief Config interface extension for the Document and View.
*
* \ingroup kte_group_view_extensions
* \ingroup kte_group_doc_extensions
*
* \section config_intro Introduction
*
* The ConfigInterface provides methods to access and modify the low level
* config information for a given Document or View. Examples of this config data can be
* displaying the icon bar, showing line numbers, etc. This generally allows
* access to settings that otherwise are only accessible during runtime.
*
* \section config_access Accessing the Interface
*
* The ConfigInterface is supposed to be an extension interface for a Document or View,
* i.e. the Document or View inherits the interface \e provided that the
* KTextEditor library in use implements the interface. Use qobject_cast to access
* the interface:
* \code
* // ptr is of type KTextEditor::Document* or KTextEditor::View*
* KTextEditor::ConfigInterface *iface =
* qobject_cast<KTextEditor::ConfigInterface*>( ptr );
*
* if( iface ) {
*
* // the implementation supports the interface
* // do stuff
* }
* \endcode
*
* \section config_data Accessing Data
*
* A list of available config variables (or keys) can be optained by calling
* configKeys(). For all available keys configValue() returns the corresponding
* value as QVariant. A value for a given key can be set by calling
* setConfigValue(). Right now, when using KatePart as editor component,
* KTextEditor::View has support for the following tuples:
* - line-numbers [bool], show/hide line numbers
* - icon-bar [bool], show/hide icon bar
* - dynamic-word-wrap [bool], enable/disable dynamic word wrap
* - background-color [QColor], read/set the default background color
* - selection-color [QColor], read/set the default color for selections
* - search-highlight-color [QColor], read/set the background color for search
* - replace-highlight-color [QColor], read/set the background color for replaces
* - default-mark-type [uint], read/set the default mark type
* - allow-mark-menu [bool], enable/disable the menu shown when right clicking
* on the left gutter. When disabled, click on the gutter will always set
* or clear the mark of default type.
*
* KTextEditor::Document has support for the following:
* - backup-on-save-local [bool], enable/disable backup when saving local files
* - backup-on-save-remote [bool], enable/disable backup when saving remote files
* - backup-on-save-suffix [string], set the suffix for file backups, e.g. "~"
* - backup-on-save-prefix [string], set the prefix for file backups, e.g. "."
*
* Either interface should emit the \p configChanged signal when appropriate.
* TODO: Add to interface in KDE 5.
*
* For instance, if you want to enable dynamic word wrap of a KTextEditor::View
* simply call
* \code
* iface->setConfigValue("dynamic-word-wrap", true);
* \endcode
*
* \see KTextEditor::View, KTextEditor::Document
* \author Matt Broadstone \<mbroadst@gmail.com\>
*/
class KTEXTEDITOR_EXPORT ConfigInterface
{
public:
ConfigInterface ();
/**
* Virtual destructor.
*/
virtual ~ConfigInterface ();
public:
/**
* Get a list of all available keys.
*/
virtual QStringList configKeys() const = 0;
/**
* Get a value for the \p key.
*/
virtual QVariant configValue(const QString &key) = 0;
/**
* Set a the \p key's value to \p value.
*/
virtual void setConfigValue(const QString &key, const QVariant &value) = 0;
private:
class ConfigInterfacePrivate* const d;
};
}
Q_DECLARE_INTERFACE(KTextEditor::ConfigInterface, "org.kde.KTextEditor.ConfigInterface")
#endif
// kate: space-indent on; indent-width 2; replace-tabs on;
|