// -*- C++ -*- /** * \file GuiCommandBuffer.h * This file is part of LyX, the document processor. * Licence details can be found in the file COPYING. * * \author Lars * \author Asger and Jürgen * \author John Levon * * Full author contact details are available in file CREDITS. */ #ifndef GUICOMMANDBUFFER_H #define GUICOMMANDBUFFER_H #include "support/docstring.h" #include #include #include class QListWidgetItem; namespace lyx { class DispatchResult; namespace frontend { class GuiView; class GuiCommandEdit; class GuiCommandBuffer : public QWidget { Q_OBJECT public: GuiCommandBuffer(GuiView * view); public Q_SLOTS: /// dispatch a command void dispatch(); /// tab-complete void complete(); /// show history void listHistoryUp(); /// called when an item in a list is selected void itemSelected(QListWidgetItem *); /// up void up(); /// down void down(); /// leave and hide the command buffer void hideParent(); private: /// owning view GuiView * view_; /// command widget GuiCommandEdit * edit_; /// return the previous history entry if any std::string const historyUp(); /// return the next history entry if any std::string const historyDown(); /// open a listbox and show the contents of the list. When reversed /// is true, the contents of the list is filled bottom-up. void showList(std::vector const & list, QPoint const & pos, bool reversed = false) const; /// return the possible completions std::vector const completions(std::string const & prefix, std::string & new_prefix); /// dispatch a command DispatchResult const & dispatch(std::string const & str); /// current position in command history std::vector::const_iterator history_pos_; /// the button up QPushButton * upPB; /// the button down QPushButton * downPB; }; } // namespace frontend } // namespace lyx #endif // GUICOMMANDBUFFER_H