mirror of https://github.com/cutefishos/terminal
				
				
				
			
			You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			328 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			C++
		
	
			
		
		
	
	
			328 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			C++
		
	
| /*  Copyright (C) 2008 e_k (e_k@users.sourceforge.net)
 | |
| 
 | |
|     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 _Q_TERM_WIDGET
 | |
| #define _Q_TERM_WIDGET
 | |
| 
 | |
| #include <QTranslator>
 | |
| #include <QWidget>
 | |
| #include "Emulation.h"
 | |
| #include "Filter.h"
 | |
| 
 | |
| class QVBoxLayout;
 | |
| struct TermWidgetImpl;
 | |
| class SearchBar;
 | |
| class QUrl;
 | |
| 
 | |
| class QTermWidget : public QWidget {
 | |
|     Q_OBJECT
 | |
| public:
 | |
| 
 | |
|     /**
 | |
|      * This enum describes the location where the scroll bar is positioned in the display widget.
 | |
|      */
 | |
|     enum ScrollBarPosition {
 | |
|         /** Do not show the scroll bar. */
 | |
|         NoScrollBar = 0,
 | |
|         /** Show the scroll bar on the left side of the display. */
 | |
|         ScrollBarLeft = 1,
 | |
|         /** Show the scroll bar on the right side of the display. */
 | |
|         ScrollBarRight = 2
 | |
|     };
 | |
| 
 | |
|     using KeyboardCursorShape = Konsole::Emulation::KeyboardCursorShape;
 | |
| 
 | |
|     //Creation of widget
 | |
|     QTermWidget(int startnow, // 1 = start shell programm immediatelly
 | |
|                 QWidget * parent = 0);
 | |
|     // A dummy constructor for Qt Designer. startnow is 1 by default
 | |
|     QTermWidget(QWidget *parent = 0);
 | |
| 
 | |
|     virtual ~QTermWidget();
 | |
| 
 | |
|     //Initial size
 | |
|     QSize sizeHint() const;
 | |
| 
 | |
|     // expose TerminalDisplay::TerminalSizeHint, setTerminalSizeHint
 | |
|     void setTerminalSizeHint(bool on);
 | |
|     bool terminalSizeHint();
 | |
| 
 | |
|     //start shell program if it was not started in constructor
 | |
|     void startShellProgram();
 | |
| 
 | |
|     /**
 | |
|      * Start terminal teletype as is
 | |
|      * and redirect data for external recipient.
 | |
|      * It can be used for display and control a remote terminal.
 | |
|      */
 | |
|     void startTerminalTeletype();
 | |
| 
 | |
|     int getShellPID();
 | |
| 
 | |
|     void changeDir(const QString & dir);
 | |
| 
 | |
|     //look-n-feel, if you don`t like defaults
 | |
| 
 | |
|     //  Terminal font
 | |
|     // Default is application font with family Monospace, size 10
 | |
|     // Beware of a performance penalty and display/alignment issues when using a proportional font.
 | |
|     void setTerminalFont(const QFont & font);
 | |
|     QFont getTerminalFont();
 | |
|     void setTerminalOpacity(qreal level);
 | |
|     void setTerminalBackgroundImage(QString backgroundImage);
 | |
| 
 | |
|     //environment
 | |
|     void setEnvironment(const QStringList & environment);
 | |
| 
 | |
|     //  Shell program, default is /bin/bash
 | |
|     void setShellProgram(const QString & progname);
 | |
| 
 | |
|     //working directory
 | |
|     void setWorkingDirectory(const QString & dir);
 | |
|     QString workingDirectory();
 | |
| 
 | |
|     // Shell program args, default is none
 | |
|     void setArgs(const QStringList & args);
 | |
| 
 | |
|     //Text codec, default is UTF-8
 | |
|     void setTextCodec(QTextCodec * codec);
 | |
| 
 | |
|     /** @brief Sets the color scheme, default is white on black
 | |
|      *
 | |
|      * @param[in] name The name of the color scheme, either returned from
 | |
|      * availableColorSchemes() or a full path to a color scheme.
 | |
|      */
 | |
|     void setColorScheme(const QString & name);
 | |
|     static QStringList availableColorSchemes();
 | |
|     static void addCustomColorSchemeDir(const QString& custom_dir);
 | |
| 
 | |
|     // History size for scrolling
 | |
|     void setHistorySize(int lines); //infinite if lines < 0
 | |
| 
 | |
|     // Presence of scrollbar
 | |
|     void setScrollBarPosition(ScrollBarPosition);
 | |
| 
 | |
|     // Wrapped, scroll to end.
 | |
|     void scrollToEnd();
 | |
| 
 | |
|     // Send some text to terminal
 | |
|     void sendText(const QString & text);
 | |
| 
 | |
|     // Sets whether flow control is enabled
 | |
|     void setFlowControlEnabled(bool enabled);
 | |
| 
 | |
|     // Returns whether flow control is enabled
 | |
|     bool flowControlEnabled(void);
 | |
| 
 | |
|     /**
 | |
|      * Sets whether the flow control warning box should be shown
 | |
|      * when the flow control stop key (Ctrl+S) is pressed.
 | |
|      */
 | |
|     void setFlowControlWarningEnabled(bool enabled);
 | |
| 
 | |
|     /*! Get all available keyboard bindings
 | |
|      */
 | |
|     static QStringList availableKeyBindings();
 | |
| 
 | |
|     //! Return current key bindings
 | |
|     QString keyBindings();
 | |
| 
 | |
|     void setMotionAfterPasting(int);
 | |
| 
 | |
|     /** Return the number of lines in the history buffer. */
 | |
|     int historyLinesCount();
 | |
| 
 | |
|     int screenColumnsCount();
 | |
|     int screenLinesCount();
 | |
| 
 | |
|     void setSelectionStart(int row, int column);
 | |
|     void setSelectionEnd(int row, int column);
 | |
|     void getSelectionStart(int& row, int& column);
 | |
|     void getSelectionEnd(int& row, int& column);
 | |
| 
 | |
|     /**
 | |
|      * Returns the currently selected text.
 | |
|      * @param preserveLineBreaks Specifies whether new line characters should
 | |
|      * be inserted into the returned text at the end of each terminal line.
 | |
|      */
 | |
|     QString selectedText(bool preserveLineBreaks = true);
 | |
| 
 | |
|     void setMonitorActivity(bool);
 | |
|     void setMonitorSilence(bool);
 | |
|     void setSilenceTimeout(int seconds);
 | |
| 
 | |
|     /** Returns the available hotspot for the given point \em pos.
 | |
|      *
 | |
|      * This method may return a nullptr if no hotspot is available.
 | |
|      *
 | |
|      * @param[in] pos The point of interest in the QTermWidget coordinates.
 | |
|      * @return Hotspot for the given position, or nullptr if no hotspot.
 | |
|      */
 | |
|     Filter::HotSpot* getHotSpotAt(const QPoint& pos) const;
 | |
| 
 | |
|     /** Returns the available hotspots for the given row and column.
 | |
|      *
 | |
|      * @return Hotspot for the given position, or nullptr if no hotspot.
 | |
|      */
 | |
|     Filter::HotSpot* getHotSpotAt(int row, int column) const;
 | |
| 
 | |
|     /*
 | |
|      * Proxy for TerminalDisplay::filterActions
 | |
|      * */
 | |
|     QList<QAction*> filterActions(const QPoint& position, QWidget* parent);
 | |
| 
 | |
|     /**
 | |
|      * Returns a pty slave file descriptor.
 | |
|      * This can be used for display and control
 | |
|      * a remote terminal.
 | |
|      */
 | |
|     int getPtySlaveFd() const;
 | |
| 
 | |
|     /**
 | |
|      * Sets the shape of the keyboard cursor.  This is the cursor drawn
 | |
|      * at the position in the terminal where keyboard input will appear.
 | |
|      */
 | |
|     void setKeyboardCursorShape(KeyboardCursorShape shape);
 | |
| 
 | |
|     void setBlinkingCursor(bool blink);
 | |
| 
 | |
|     /** Enables or disables bidi text in the terminal. */
 | |
|     void setBidiEnabled(bool enabled);
 | |
|     bool isBidiEnabled();
 | |
| 
 | |
|     /**
 | |
|      * Automatically close the terminal session after the shell process exits or
 | |
|      * keep it running.
 | |
|      */
 | |
|     void setAutoClose(bool);
 | |
| 
 | |
|     QString title() const;
 | |
|     QString icon() const;
 | |
| 
 | |
|     /** True if the title() or icon() was (ever) changed by the session. */
 | |
|     bool isTitleChanged() const;
 | |
| 
 | |
|     /** change and wrap text corresponding to paste mode **/
 | |
|     void bracketText(QString& text);
 | |
| 
 | |
|     /** Set the empty space outside the terminal */
 | |
|     void setMargin(int);
 | |
| 
 | |
|     /** Get the empty space outside the terminal */
 | |
|     int getMargin() const;
 | |
| signals:
 | |
|     void finished();
 | |
|     void copyAvailable(bool);
 | |
| 
 | |
|     void termGetFocus();
 | |
|     void termLostFocus();
 | |
| 
 | |
|     void termKeyPressed(QKeyEvent *);
 | |
| 
 | |
|     void urlActivated(const QUrl&, bool fromContextMenu);
 | |
| 
 | |
|     void bell(const QString& message);
 | |
| 
 | |
|     void activity();
 | |
|     void silence();
 | |
| 
 | |
|     /**
 | |
|      * Emitted when emulator send data to the terminal process
 | |
|      * (redirected for external recipient). It can be used for
 | |
|      * control and display the remote terminal.
 | |
|      */
 | |
|     void sendData(const char *,int);
 | |
| 
 | |
|     void profileChanged(const QString & profile);
 | |
| 
 | |
|     void titleChanged();
 | |
| 
 | |
|     /**
 | |
|      * Signals that we received new data from the process running in the
 | |
|      * terminal emulator
 | |
|      */
 | |
|     void receivedData(const QString &text);
 | |
| 
 | |
| public slots:
 | |
|     // Copy selection to clipboard
 | |
|     void copyClipboard();
 | |
| 
 | |
|     // Paste clipboard to terminal
 | |
|     void pasteClipboard();
 | |
| 
 | |
|     // Paste selection to terminal
 | |
|     void pasteSelection();
 | |
| 
 | |
|     // Set zoom
 | |
|     void zoomIn();
 | |
|     void zoomOut();
 | |
| 
 | |
|     // Set size
 | |
|     void setSize(const QSize &);
 | |
| 
 | |
|     /*! Set named key binding for given widget
 | |
|      */
 | |
|     void setKeyBindings(const QString & kb);
 | |
| 
 | |
|     /*! Clear the terminal content and move to home position
 | |
|      */
 | |
|     void clear();
 | |
| 
 | |
|     void toggleShowSearchBar();
 | |
| 
 | |
| protected:
 | |
|     virtual void resizeEvent(QResizeEvent *);
 | |
| 
 | |
| protected slots:
 | |
|     void sessionFinished();
 | |
|     void selectionChanged(bool textSelected);
 | |
| 
 | |
| private slots:
 | |
|     void find();
 | |
|     void findNext();
 | |
|     void findPrevious();
 | |
|     void matchFound(int startColumn, int startLine, int endColumn, int endLine);
 | |
|     void noMatchFound();
 | |
|     /**
 | |
|      * Emulation::cursorChanged() signal propogates to here and QTermWidget
 | |
|      * sends the specified cursor states to the terminal display
 | |
|      */
 | |
|     void cursorChanged(Konsole::Emulation::KeyboardCursorShape cursorShape, bool blinkingCursorEnabled);
 | |
| 
 | |
| private:
 | |
|     void search(bool forwards, bool next);
 | |
|     void setZoom(int step);
 | |
|     void init(int startnow);
 | |
|     TermWidgetImpl * m_impl;
 | |
|     SearchBar* m_searchBar;
 | |
|     QVBoxLayout *m_layout;
 | |
|     QTranslator *m_translator;
 | |
| };
 | |
| 
 | |
| 
 | |
| //Maybe useful, maybe not
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C"
 | |
| #endif
 | |
| void * createTermWidget(int startnow, void * parent);
 | |
| 
 | |
| #endif
 | |
| 
 |