/usr/include/ktexteditor/commandinterface.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 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 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 | /* This file is part of the KDE project
Copyright (C) 2005 Christoph Cullmann (cullmann@kde.org)
Copyright (C) 2005-2006 Dominik Haumann (dhdev@gmx.de)
Copyright (C) 2008 Erlend Hamberg (ehamberg@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_COMMANDINTERFACE_H
#define KDELIBS_KTEXTEDITOR_COMMANDINTERFACE_H
#include <ktexteditor/ktexteditor_export.h>
#include <ktexteditor/range.h>
#include <QtCore/QObject>
class QStringList;
class KCompletion;
namespace KTextEditor
{
class Editor;
class View;
/**
* \brief An Editor command line command.
*
* \section cmd_intro Introduction
*
* The Command class represents a command for the editor command line. A
* command simply consists of a string, for example \e find. To register a
* command use CommandInterface::registerCommand(). The Editor itself queries
* the command for a list of accepted strings/commands by calling cmds().
* If the command gets invoked the function exec() is called, i.e. you have
* to implement the \e reaction in exec(). Whenever the user needs help for
* a command help() is called.
*
* \section cmd_information Command Information
* To provide reasonable information about a specific command there are the
* following accessor functions for a given command string:
* - name() returns a label
* - description() returns a descriptive text
* - category() returns a category into which the command fits.
*
* These getters allow KTextEditor implementations to plug commands into menus
* and toolbars, so that a user can assign shortcuts.
*
* \section cmd_extension Command Extensions
*
* If your command needs to interactively react on changes while the user is
* typing text - look at the \e ifind command in Kate for example - you have
* to additionally derive your command from the class CommandExtension. The
* command extension provides methods to give help on \e flags or add a
* KCompletion object and process the typed text interactively. Besides that
* the class RangeCommand enables you to support ranges so that you can apply
* commands on regions of text.
*
* \see KTextEditor::CommandInterface, KTextEditor::CommandExtension,
* KTextEditor::RangeCommand
* \author Christoph Cullmann \<cullmann@kde.org\>
* \note KDE5: derive from QObject, so qobject_cast works for extension interfaces.
*/
class KTEXTEDITOR_EXPORT Command
{
public:
/**
* Virtual destructor.
*/
virtual ~Command () {}
public:
/**
* Return a list of strings a command may begin with.
* A string is the start part of a pure text which can be handled by this
* command, i.e. for the command s/sdl/sdf/g the corresponding string is
* simply \e s, and for char:1212 simply \e char.
* \return list of supported commands
*/
virtual const QStringList &cmds () = 0;
/**
* Execute the command for the given \p view and \p cmd string.
* Return the success value and a \p msg for status. As example we
* consider a replace command. The replace command would return the number
* of replaced strings as \p msg, like "16 replacements made." If an error
* occurred in the usage it would return \e false and set the \p msg to
* something like "missing argument." or such.
*
* \return \e true on success, otherwise \e false
*/
virtual bool exec (KTextEditor::View *view, const QString &cmd, QString &msg) = 0;
/**
* Shows help for the given \p view and \p cmd string.
* If your command has a help text for \p cmd you have to return \e true
* and set the \p msg to a meaningful text. The help text is embedded by
* the Editor in a Qt::RichText enabled widget, e.g. a QToolTip.
* \return \e true if your command has a help text, otherwise \e false
*/
virtual bool help (KTextEditor::View *view, const QString &cmd, QString &msg) = 0;
};
/**
* \brief Extension interface for a Command.
*
* \ingroup kte_group_command_extensions
*
* \section cmdext_intro Introduction
*
* The CommandExtension extends the Command interface allowing to interact
* with commands during typing. This allows for completion and for example
* the isearch plugin. If you develop a command that wants to complete or
* process text as the user types the arguments, or that has flags, you can
* have your command inherit this class.
*
* If your command supports flags return them by reimplementing
* flagCompletions(). You can return your own KCompletion object if the
* command has available completion data. If you want to interactively react
* on changes return \e true in wantsToProcessText() for the given command
* and reimplement processText().
*
* \see KTextEditor::CommandInterface, KTextEditor::Command, KCompletion
* \author Christoph Cullmann \<cullmann@kde.org\>
*/
class KTEXTEDITOR_EXPORT CommandExtension
{
public:
/**
* Virtual destructor.
*/
virtual ~CommandExtension() {}
/**
* Fill in a \p list of flags to complete from. Each flag is a single
* letter, any following text in the string is taken to be a description
* of the flag's meaning, and showed to the user as a hint.
* Implement this method if your command has flags.
*
* This method is called each time the flag string in the typed command
* is changed, so that the available flags can be adjusted. When
* completions are displayed, existing flags are left out.
* \param list flag list
*/ //### this is yet to be tried
virtual void flagCompletions( QStringList&list ) = 0;
/**
* Return a KCompletion object that will substitute the command line
* default one while typing the first argument of the command \p cmdname.
* The text will be added to the command separated by one space character.
*
* Implement this method if your command can provide a completion object.
*
* \param view the view the command will work on
* \param cmdname the command name associated with this request.
* \return the completion object or NULL, if you do not support a
* completion object
*/
virtual KCompletion *completionObject( KTextEditor::View *view,
const QString & cmdname ) = 0;
/**
* Check, whether the command wants to process text interactively for the
* given command with name \p cmdname.
* If you return true, the command's processText() method is called
* whenever the text in the command line changed.
*
* Reimplement this to return true, if your commands wants to process the
* text while typing.
*
* \param cmdname the command name associated with this query.
* \return \e true, if your command wants to process text interactively,
* otherwise \e false
* \see processText()
*/
virtual bool wantsToProcessText( const QString &cmdname ) = 0;
/**
* This is called by the command line each time the argument text for the
* command changed, if wantsToProcessText() returns \e true.
* \param view the current view
* \param text the current command text typed by the user
* \see wantsToProcessText()
*/ // ### yet to be tested. The obvious candidate is isearch.
virtual void processText( KTextEditor::View *view, const QString &text ) = 0;
};
/**
* \brief Command extension interface for the Editor.
*
* \ingroup kte_group_editor_extensions
*
* \section cmdiface_intro Introduction
*
* The CommandInterface extends the Editor to support command line commands.
* An application or a Plugin can register new commands by using
* registerCommand(). To unregister a command call unregisterCommand(). To
* check, whether a command with a given name exists use queryCommand().
*
* \section cmdiface_access Accessing the CommandInterface
*
* The CommandInterface is supposed to be an extension interface for the
* Editor, i.e. the Editor inherits the interface \e provided that the
* used KTextEditor library implements the interface. Use qobject_cast to
* access the interface:
* \code
* // editor is of type KTextEditor::Editor*
* KTextEditor::CommandInterface *iface =
* qobject_cast<KTextEditor::CommandInterface*>( editor );
*
* if( iface ) {
* // the implementation supports the interface
* // do stuff
* }
* \endcode
*
* \see KTextEditor::Editor, KTextEditor::Command,
* KTextEditor::CommandExtension
* \author Christoph Cullmann \<cullmann@kde.org\>
*/
class KTEXTEDITOR_EXPORT CommandInterface
{
public:
/**
* Virtual destructor.
*/
virtual ~CommandInterface () {}
public:
/**
* Register a the new command \p cmd. The command will be registered for
* all documents, i.e. every command is global.
*
* \param cmd command to register
* \return \e true on success, otherwise \e false
* \see unregisterCommand()
*/
virtual bool registerCommand (Command *cmd) = 0;
/**
* Unregister the command \p cmd. The command will be unregistered for
* all documents.
*
* \param cmd command to unregister
* \return \e true on success, otherwise \e false
* \see registerCommand()
*/
virtual bool unregisterCommand (Command *cmd) = 0;
/**
* Query for the command \p cmd.
* If the command \p cmd does not exist the return value is NULL.
*
* \param cmd name of command to query for
* \return the found command or NULL if no such command exists
*/
virtual Command *queryCommand (const QString &cmd) const = 0;
/**
* Get a list of all registered commands.
* \return list of all commands
* \see queryCommand(), commandList()
*/
virtual QList<Command*> commands() const = 0;
/**
* Get a list of available command line strings.
* \return command line strings
* \see commands()
*/
virtual QStringList commandList() const = 0;
};
/**
* \brief Extension interface for a Command making the exec method take a line
* range
*
* \ingroup kte_group_command_extensions
*
* \section cmdext_intro Introduction
*
* The RangeCommand extension extends the Command interface by making it
* possible to send a range to a command indicating that it should only do its
* work on those lines.
*
* The method supportsRange() takes a QString reference and should return true
* if the given command name supports a range and false if not.
*
* \see KTextEditor::CommandInterface, KTextEditor::Command, KTextEditor::Range
* \author Erlend Hamberg \<ehamberg@gmail.com\>
* \since 4.2
* \note KDE5: merge with KTextEditor::Command?
*/
class KTEXTEDITOR_EXPORT RangeCommand
{
public:
/**
* Virtual destructor.
*/
virtual ~RangeCommand() {}
/**
* Execute the command for the given \p range on the given \p view and \p
* cmd string. Return the success value and a \p msg for status.
*
* \return \e true on success, otherwise \e false
*/
virtual bool exec (KTextEditor::View *view, const QString &cmd, QString &msg,
const KTextEditor::Range &range) = 0;
/**
* Find out if a given command can act on a range. This is used for checking
* if a command should be called when the user also gave a range or if an
* error should be raised.
*
* \return \e true if command supports acting on a range of lines, false if
* not
*/
virtual bool supportsRange (const QString &cmd) = 0;
};
}
Q_DECLARE_INTERFACE(KTextEditor::CommandInterface, "org.kde.KTextEditor.CommandInterface")
#endif
// kate: space-indent on; indent-width 2; replace-tabs on;
|