mirror of
https://bitbucket.org/smil3y/kde-workspace.git
synced 2025-02-24 02:42:50 +00:00
191 lines
5.5 KiB
C++
191 lines
5.5 KiB
C++
/*
|
|
This file is part of Konsole, KDE's terminal emulator.
|
|
|
|
Copyright 2007-2008 by Robert Knight <robertknight@gmail.com>
|
|
Copyright 1997,1998 by Lars Doelle <lars.doelle@on-line.de>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program 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 General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
02110-1301 USA.
|
|
*/
|
|
|
|
#ifndef PTY_H
|
|
#define PTY_H
|
|
|
|
// Qt
|
|
#include <QtCore/QSize>
|
|
|
|
// KDE
|
|
#include <KPtyProcess>
|
|
|
|
// Konsole
|
|
#include "konsoleprivate_export.h"
|
|
|
|
#include <QStringList>
|
|
|
|
namespace Konsole
|
|
{
|
|
/**
|
|
* The Pty class is used to start the terminal process,
|
|
* send data to it, receive data from it and manipulate
|
|
* various properties of the pseudo-teletype interface
|
|
* used to communicate with the process.
|
|
*
|
|
* To use this class, construct an instance and connect
|
|
* to the sendData slot and receivedData signal to
|
|
* send data to or receive data from the process.
|
|
*
|
|
* To start the terminal process, call the start() method
|
|
* with the program name and appropriate arguments.
|
|
*/
|
|
class KONSOLEPRIVATE_EXPORT Pty: public KPtyProcess
|
|
{
|
|
Q_OBJECT
|
|
|
|
public:
|
|
/**
|
|
* Constructs a new Pty.
|
|
*
|
|
* Connect to the sendData() slot and receivedData() signal to prepare
|
|
* for sending and receiving data from the terminal process.
|
|
*
|
|
* To start the terminal process, call the run() method with the
|
|
* name of the program to start and appropriate arguments.
|
|
*/
|
|
explicit Pty(QObject* parent = 0);
|
|
|
|
/**
|
|
* Construct a process using an open pty master.
|
|
* See KPtyProcess::KPtyProcess()
|
|
*/
|
|
explicit Pty(int ptyMasterFd, QObject* parent = 0);
|
|
|
|
~Pty();
|
|
|
|
/**
|
|
* Starts the terminal process.
|
|
*
|
|
* Returns 0 if the process was started successfully or non-zero
|
|
* otherwise.
|
|
*
|
|
* @param program Path to the program to start
|
|
* @param arguments Arguments to pass to the program being started
|
|
* @param environment A list of key=value pairs which will be added
|
|
* to the environment for the new process. At the very least this
|
|
* should include an assignment for the TERM environment variable.
|
|
*/
|
|
int start(const QString& program,
|
|
const QStringList& arguments,
|
|
const QStringList& environment
|
|
);
|
|
|
|
/** Control whether the pty device is writeable by group members. */
|
|
void setWriteable(bool writeable);
|
|
|
|
/**
|
|
* Enables or disables Xon/Xoff flow control. The flow control setting
|
|
* may be changed later by a terminal application, so flowControlEnabled()
|
|
* may not equal the value of @p on in the previous call to setFlowControlEnabled()
|
|
*/
|
|
void setFlowControlEnabled(bool on);
|
|
|
|
/** Queries the terminal state and returns true if Xon/Xoff flow control is enabled. */
|
|
bool flowControlEnabled() const;
|
|
|
|
/**
|
|
* Sets the size of the window (in columns and lines of characters)
|
|
* used by this teletype.
|
|
*/
|
|
void setWindowSize(int columns, int lines);
|
|
|
|
/** Returns the size of the window used by this teletype. See setWindowSize() */
|
|
QSize windowSize() const;
|
|
|
|
/**
|
|
* Sets the special character for erasing previous not-yet-erased character.
|
|
* See termios(3) for detailed description.
|
|
*/
|
|
void setEraseChar(char eraseChar);
|
|
|
|
/** */
|
|
char eraseChar() const;
|
|
|
|
/**
|
|
* Sets the initial working directory.
|
|
*/
|
|
void setInitialWorkingDirectory(const QString& dir);
|
|
|
|
/**
|
|
* Returns the process id of the teletype's current foreground
|
|
* process. This is the process which is currently reading
|
|
* input sent to the terminal via. sendData()
|
|
*
|
|
* If there is a problem reading the foreground process group,
|
|
* 0 will be returned.
|
|
*/
|
|
int foregroundProcessGroup() const;
|
|
|
|
/**
|
|
* Close the underlying pty master/slave pair.
|
|
*/
|
|
void closePty();
|
|
|
|
public slots:
|
|
/**
|
|
* Put the pty into UTF-8 mode on systems which support it.
|
|
*/
|
|
void setUtf8Mode(bool on);
|
|
|
|
/**
|
|
* Sends data to the process currently controlling the
|
|
* teletype ( whose id is returned by foregroundProcessGroup() )
|
|
*
|
|
* @param buffer Pointer to the data to send.
|
|
* @param length Length of @p buffer.
|
|
*/
|
|
void sendData(const char* buffer, int length);
|
|
|
|
signals:
|
|
/**
|
|
* Emitted when a new block of data is received from
|
|
* the teletype.
|
|
*
|
|
* @param buffer Pointer to the data received.
|
|
* @param length Length of @p buffer
|
|
*/
|
|
void receivedData(const char* buffer, int length);
|
|
|
|
protected:
|
|
void setupChildProcess();
|
|
|
|
private slots:
|
|
// called when data is received from the terminal process
|
|
void dataReceived();
|
|
|
|
private:
|
|
void init();
|
|
|
|
// takes a list of key=value pairs and adds them
|
|
// to the environment for the process
|
|
void addEnvironmentVariables(const QStringList& environment);
|
|
|
|
int _windowColumns;
|
|
int _windowLines;
|
|
char _eraseChar;
|
|
bool _xonXoff;
|
|
bool _utf8;
|
|
};
|
|
}
|
|
|
|
#endif // PTY_H
|