123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0.txt
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- =========================================================================*/
- /*=========================================================================
- Program: ParaView
- Copyright (c) 2005-2008 Sandia Corporation, Kitware Inc.
- All rights reserved.
- ParaView is a free software; you can redistribute it and/or modify it
- under the terms of the ParaView license version 1.2.
- See http://www.paraview.org/paraview/project/license.html for the full ParaView license.
- A copy of this license can be obtained by contacting
- Kitware Inc.
- 28 Corporate Drive
- Clifton Park, NY 12065
- USA
- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
- A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR
- CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
- EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
- PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
- LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
- NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
- SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
- =========================================================================*/
- #ifndef __ctkConsole_h
- #define __ctkConsole_h
- // Qt includes
- #include <QWidget>
- #include <QTextCharFormat>
- #include <QCompleter>
- // CTK includes
- #include "ctkWidgetsExport.h"
- class ctkConsolePrivate;
- class ctkConsoleCompleter;
- /// \ingroup Widgets
- /// QWidget that provides an interactive console
- class CTK_WIDGETS_EXPORT ctkConsole : public QWidget
- {
- Q_OBJECT
- Q_PROPERTY(QColor promptColor READ promptColor WRITE setPromptColor)
- Q_PROPERTY(QColor outputTextColor READ outputTextColor WRITE setOutputTextColor)
- Q_PROPERTY(QColor errorTextColor READ errorTextColor WRITE setErrorTextColor)
- Q_PROPERTY(QColor stdinTextColor READ stdinTextColor WRITE setStdinTextColor)
- Q_PROPERTY(QColor commandTextColor READ commandTextColor WRITE setCommandTextColor)
- Q_PROPERTY(QColor welcomeTextColor READ welcomeTextColor WRITE setWelcomeTextColor)
- Q_PROPERTY(QColor backgroundColor READ backgroundColor WRITE setBackgroundColor)
- Q_PROPERTY(QString ps1 READ ps1 WRITE setPs1)
- Q_PROPERTY(QString ps2 READ ps2 WRITE setPs2)
- Q_FLAGS(EditorHint EditorHints)
- Q_PROPERTY(EditorHints editorHints READ editorHints WRITE setEditorHints)
- Q_ENUMS(Qt::ScrollBarPolicy)
- Q_PROPERTY(Qt::ScrollBarPolicy scrollBarPolicy READ scrollBarPolicy WRITE setScrollBarPolicy)
-
- public:
- enum EditorHint
- {
- NoHints = 0x00,
- AutomaticIndentation = 0x01, /*!< Align cursor based an indentation of the previous command */
- RemoveTrailingSpaces = 0x02, /*!< Remove trailing spaces of the entered command */
- SplitCopiedTextByLine = 0x4 /*!< Copied text is split by lines and each one is executed (expected the last one) */
- };
- Q_DECLARE_FLAGS(EditorHints, EditorHint)
- ctkConsole(QWidget* parentObject = 0);
- typedef QWidget Superclass;
- virtual ~ctkConsole();
- /// Returns the current formatting that will be used by printMessage()
- QTextCharFormat getFormat() const;
-
- /// Sets formatting that will be used by printMessage()
- void setFormat(const QTextCharFormat& Format);
- /// Return the completer of this console
- ctkConsoleCompleter* completer() const;
- /// Set a completer for this console
- void setCompleter(ctkConsoleCompleter* completer);
- QColor promptColor()const;
- /// \sa promptColor()
- void setPromptColor(const QColor& newColor);
- QColor outputTextColor()const;
- /// \sa outputTextColor()
- void setOutputTextColor(const QColor& newColor);
- QColor errorTextColor()const;
- /// \sa errorTextColor()
- void setErrorTextColor(const QColor& newColor);
- QColor stdinTextColor()const;
- /// \sa stdinTextColor()
- void setStdinTextColor(const QColor& newColor);
- QColor commandTextColor()const;
- /// \sa commandTextColor()
- void setCommandTextColor(const QColor& newColor);
- QColor welcomeTextColor()const;
- /// \sa welcomeTextColor()
- void setWelcomeTextColor(const QColor& newColor);
- QColor backgroundColor()const;
- void setBackgroundColor(const QColor& newColor);
- EditorHints editorHints()const;
- /// \sa editorHints()
- void setEditorHints(const EditorHints& newEditorHints);
- Qt::ScrollBarPolicy scrollBarPolicy()const;
- /// \sa scrollBarPolicy()
- void setScrollBarPolicy(const Qt::ScrollBarPolicy& newScrollBarPolicy);
- /// Prints text on the console
- void printMessage(const QString& message, const QColor& color);
- /// Returns the string used as primary prompt
- virtual QString ps1() const;
- /// Set the string used as primary prompt
- virtual void setPs1(const QString& newPs1);
- /// Returns the string used as secondary prompt
- virtual QString ps2() const;
- /// Set the string used as secondary prompt
- virtual void setPs2(const QString& newPs2);
- static QString stdInRedirectCallBack(void * callData);
- Q_SIGNALS:
- /// This signal emitted before and after a command is executed
- void aboutToExecute(const QString&);
- void executed(const QString&);
- public Q_SLOTS:
- /// Clears the contents of the console
- virtual void clear();
- /// Clears the contents of the console and display welcome message
- virtual void reset();
- /// Exec the contents of the last console line
- virtual void exec(const QString&);
- protected:
- /// Prompt the user for input
- QString readInputLine();
- /// Called whenever the user enters a command
- virtual void executeCommand(const QString& Command);
- protected:
- ctkConsole(ctkConsolePrivate * pimpl, QWidget* parentObject);
- QScopedPointer<ctkConsolePrivate> d_ptr;
- private:
- Q_DECLARE_PRIVATE(ctkConsole);
- Q_DISABLE_COPY(ctkConsole);
- };
- Q_DECLARE_OPERATORS_FOR_FLAGS(ctkConsole::EditorHints);
- //-----------------------------------------------------------------------------
- class CTK_WIDGETS_EXPORT ctkConsoleCompleter : public QCompleter
- {
- public:
- /// Update the completion model given a string. The given string
- /// is the current console text between the cursor and the start of
- /// the line.
- virtual void updateCompletionModel(const QString& str) = 0;
- /// Returns the autocomplete preference list
- QStringList autocompletePreferenceList();
- /// Set autocomplete preference list
- /// This list allows to specify options that could be
- /// selected by default if multiple choices are proposed to the user.
- void setAutocompletePreferenceList(const QStringList& list);
- protected:
- QStringList AutocompletePreferenceList;
- };
- #endif
|