You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
212 lines
7.2 KiB
212 lines
7.2 KiB
/* |
|
SPDX-FileCopyrightText: 2007-2008 Robert Knight <robertknight@gmail.com> |
|
|
|
SPDX-License-Identifier: GPL-2.0-or-later |
|
*/ |
|
|
|
#ifndef PART_H |
|
#define PART_H |
|
|
|
// KDE |
|
#include <KParts/ReadOnlyPart> |
|
#include <kde_terminal_interface.h> |
|
|
|
// Qt |
|
#include <QVariantList> |
|
|
|
// Konsole |
|
#include "session/Session.h" |
|
#include "config-konsole.h" |
|
|
|
class QStringList; |
|
class QKeyEvent; |
|
|
|
namespace Konsole { |
|
class Session; |
|
class SessionController; |
|
class ViewManager; |
|
class ViewProperties; |
|
|
|
/** |
|
* A re-usable terminal emulator component using the KParts framework which can |
|
* be used to embed terminal emulators into other applications. |
|
*/ |
|
#ifdef USE_TERMINALINTERFACEV2 |
|
class Part : public KParts::ReadOnlyPart, public TerminalInterfaceV2 |
|
{ |
|
Q_OBJECT |
|
Q_INTERFACES(TerminalInterface TerminalInterfaceV2) |
|
#else |
|
class TerminalInterfaceV2; |
|
class Part : public KParts::ReadOnlyPart, public TerminalInterface |
|
{ |
|
Q_OBJECT |
|
Q_INTERFACES(TerminalInterface) |
|
#endif |
|
public: |
|
/** Constructs a new Konsole part with the specified parent. */ |
|
explicit Part(QWidget *parentWidget, QObject *parent, const QVariantList &); |
|
~Part() override; |
|
|
|
/** Reimplemented from TerminalInterface. */ |
|
void startProgram(const QString &program, const QStringList &arguments) override; |
|
/** Reimplemented from TerminalInterface. */ |
|
void showShellInDir(const QString &dir) override; |
|
/** Reimplemented from TerminalInterface. */ |
|
void sendInput(const QString &text) override; |
|
|
|
/** Reimplemented from TerminalInterface. */ |
|
int terminalProcessId() override; |
|
|
|
/** Reimplemented from TerminalInterface. */ |
|
int foregroundProcessId() override; |
|
|
|
/** Reimplemented from TerminalInterface. */ |
|
QString foregroundProcessName() override; |
|
|
|
/** Reimplemented from TerminalInterface. */ |
|
QString currentWorkingDirectory() const override; |
|
|
|
#ifdef USE_TERMINALINTERFACEV2 |
|
/** Reimplemented from TerminalInterfaceV2 */ |
|
QStringList availableProfiles() const override; |
|
|
|
/** Reimplemented from TerminalInterfaceV2 */ |
|
QString currentProfileName() const override; |
|
|
|
/** Reimplemented from TerminalInterfaceV2 */ |
|
bool setCurrentProfile(const QString &profileName) override; |
|
|
|
/** Reimplemented from TerminalInterfaceV2 */ |
|
QVariant profileProperty(const QString &profileProperty) const override; |
|
#endif |
|
|
|
public Q_SLOTS: |
|
/** |
|
* creates and run a session using the specified profile and directory |
|
* |
|
* @param profileName Specifies the name of the profile to create session |
|
* @param directory specifies The initial working directory of the created session |
|
* |
|
* This is highly experimental. Do not use it at the moment |
|
*/ |
|
void createSession(const QString &profileName = QString(), |
|
const QString &directory = QString()); |
|
|
|
void showManageProfilesDialog(QWidget* parent); |
|
|
|
/** |
|
* Shows the dialog used to edit the profile used by the active session. The |
|
* dialog will be non-modal and will delete itself when it is closed. |
|
* |
|
* This is experimental API and not guaranteed to be present in later KDE 4 |
|
* releases. |
|
* |
|
* @param parent The parent widget of the new dialog. |
|
*/ |
|
void showEditCurrentProfileDialog(QWidget *parent); |
|
/** |
|
* Sends a profile change command to the active session. This is equivalent to using |
|
* the konsoleprofile tool within the session to change its settings. The @p text string |
|
* is a semi-colon separated list of property=value pairs, eg. "colors=Linux Colors" |
|
* |
|
* See the documentation for konsoleprofile for information on the format of @p text |
|
* |
|
* This is experimental API and not guaranteed to be present in later KDE 4 releases. |
|
*/ |
|
void changeSessionSettings(const QString &text); |
|
|
|
/** |
|
* Connects to an existing pseudo-teletype. See Session::openTeletype(). |
|
* This must be called before the session is started by startProgram(), |
|
* or showShellInDir() |
|
* |
|
* @param ptyMasterFd The file descriptor of the pseudo-teletype (pty) master |
|
* @param runShell When true (default, legacy), runs the teletype in a shell |
|
* session environment. When false, the session is not run, so that the |
|
* KPtyProcess can be standalone, which may be useful for interactive programs. |
|
*/ |
|
void openTeletype(int ptyMasterFd, bool runShell = true); |
|
|
|
/** |
|
* Toggles monitoring for silence in the active session. If silence is detected, |
|
* the silenceDetected() signal is emitted. |
|
* |
|
* @param enabled Whether to enable or disable monitoring for silence. |
|
* */ |
|
void setMonitorSilenceEnabled(bool enabled); |
|
|
|
/** |
|
* Toggles monitoring for activity in the active session. If activity is detected, |
|
* the activityDetected() signal is emitted. |
|
* |
|
* @param enabled Whether to enable or disable monitoring for activity. |
|
* */ |
|
void setMonitorActivityEnabled(bool enabled); |
|
|
|
/** |
|
* Returns the status of the blur of the current profile. |
|
* |
|
* @return True if blur is enabled for the current active Konsole color profile. |
|
* */ |
|
bool isBlurEnabled(); |
|
|
|
Q_SIGNALS: |
|
/** |
|
* Emitted when the key sequence for a shortcut, which is also a valid terminal key sequence, |
|
* is pressed while the terminal has focus. By responding to this signal, the |
|
* controlling application can choose whether to execute the action associated with |
|
* the shortcut or ignore the shortcut and send the key |
|
* sequence to the terminal application. |
|
* |
|
* In the embedded terminal, shortcuts are overridden and sent to the terminal by default. |
|
* Set @p override to false to prevent this happening and allow the shortcut to be triggered |
|
* normally. |
|
* |
|
* overrideShortcut() is not called for shortcuts which are not valid terminal key sequences, |
|
* eg. shortcuts with two or more modifiers. |
|
* |
|
* @param event Describes the keys that were pressed. |
|
* @param override Set this to false to prevent the terminal display from overriding the shortcut |
|
*/ |
|
void overrideShortcut(QKeyEvent *event, bool &override); |
|
|
|
/** |
|
* Emitted when silence has been detected in the active session. Monitoring |
|
* for silence has to be enabled first using setMonitorSilenceEnabled(). |
|
*/ |
|
void silenceDetected(); |
|
|
|
/** |
|
* Emitted when activity has been detected in the active session. Monitoring |
|
* for activity has to be enabled first using setMonitorActivityEnabled(). |
|
*/ |
|
void activityDetected(); |
|
|
|
/** |
|
* Emitted when the current working directory of the active session has changed. |
|
*/ |
|
void currentDirectoryChanged(const QString &dir); |
|
|
|
protected: |
|
/** Reimplemented from KParts::PartBase. */ |
|
bool openFile() override; |
|
bool openUrl(const QUrl &url) override; |
|
|
|
private Q_SLOTS: |
|
void activeViewChanged(SessionController *controller); |
|
void activeViewTitleChanged(ViewProperties *properties); |
|
void terminalExited(); |
|
void newTab(); |
|
void overrideTerminalShortcut(QKeyEvent *, bool &override); |
|
void notificationChanged(Session::Notification notification, bool enabled); |
|
private: |
|
Session *activeSession() const; |
|
|
|
private: |
|
ViewManager *_viewManager; |
|
SessionController *_pluggedController; |
|
}; |
|
} |
|
|
|
#endif // PART_H
|
|
|