2016-09-27 22:01:08 +03:00
|
|
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
2014-12-11 21:10:03 +03:00
|
|
|
#ifndef cmCursesStringWidget_h
|
|
|
|
#define cmCursesStringWidget_h
|
2001-11-05 02:05:21 +03:00
|
|
|
|
2016-09-01 22:55:09 +03:00
|
|
|
#include <cmConfigure.h>
|
|
|
|
|
|
|
|
#include "cmCursesStandardIncludes.h"
|
2001-11-05 02:05:21 +03:00
|
|
|
#include "cmCursesWidget.h"
|
|
|
|
|
2016-09-01 22:55:09 +03:00
|
|
|
#include <string>
|
|
|
|
|
2001-12-13 21:28:41 +03:00
|
|
|
class cmCursesMainForm;
|
|
|
|
|
|
|
|
/** \class cmCursesStringWidget
|
|
|
|
* \brief A simple entry widget.
|
|
|
|
*
|
|
|
|
* cmCursesStringWdiget is a simple text entry widget.
|
|
|
|
*/
|
|
|
|
|
2001-11-05 02:05:21 +03:00
|
|
|
class cmCursesStringWidget : public cmCursesWidget
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
cmCursesStringWidget(int width, int height, int left, int top);
|
2012-08-13 21:42:58 +04:00
|
|
|
|
2001-12-13 21:28:41 +03:00
|
|
|
/**
|
|
|
|
* Handle user input. Called by the container of this widget
|
|
|
|
* when this widget has focus. Returns true if the input was
|
|
|
|
* handled.
|
|
|
|
*/
|
2016-06-27 22:25:27 +03:00
|
|
|
bool HandleInput(int& key, cmCursesMainForm* fm, WINDOW* w) CM_OVERRIDE;
|
2001-12-13 21:28:41 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Set/Get the string.
|
|
|
|
*/
|
2014-02-22 04:05:55 +04:00
|
|
|
void SetString(const std::string& value);
|
2001-11-05 02:05:21 +03:00
|
|
|
const char* GetString();
|
2016-06-27 22:25:27 +03:00
|
|
|
const char* GetValue() CM_OVERRIDE;
|
2001-11-05 02:05:21 +03:00
|
|
|
|
2001-12-13 21:28:41 +03:00
|
|
|
/**
|
|
|
|
* Set/Get InEdit flag. Can be used to tell the widget to leave
|
|
|
|
* edit mode (in case of a resize for example).
|
|
|
|
*/
|
2006-03-16 18:44:55 +03:00
|
|
|
void SetInEdit(bool inedit) { this->InEdit = inedit; }
|
|
|
|
bool GetInEdit() { return this->InEdit; }
|
2001-11-05 02:05:21 +03:00
|
|
|
|
2002-11-05 01:37:21 +03:00
|
|
|
/**
|
|
|
|
* This method is called when different keys are pressed. The
|
|
|
|
* subclass can have a special implementation handler for this.
|
|
|
|
*/
|
|
|
|
virtual void OnTab(cmCursesMainForm* fm, WINDOW* w);
|
|
|
|
virtual void OnReturn(cmCursesMainForm* fm, WINDOW* w);
|
|
|
|
virtual void OnType(int& key, cmCursesMainForm* fm, WINDOW* w);
|
|
|
|
|
2001-12-13 21:28:41 +03:00
|
|
|
/**
|
|
|
|
* If there are any, print the widget specific commands
|
|
|
|
* in the toolbar and return true. Otherwise, return false
|
|
|
|
* and the parent widget will print.
|
|
|
|
*/
|
2016-06-27 22:25:27 +03:00
|
|
|
bool PrintKeys() CM_OVERRIDE;
|
2001-12-13 21:28:41 +03:00
|
|
|
|
2001-11-05 02:05:21 +03:00
|
|
|
protected:
|
|
|
|
cmCursesStringWidget(const cmCursesStringWidget& from);
|
|
|
|
void operator=(const cmCursesStringWidget&);
|
|
|
|
|
|
|
|
// true if the widget is in edit mode
|
2006-03-16 18:44:55 +03:00
|
|
|
bool InEdit;
|
|
|
|
char* OriginalString;
|
|
|
|
bool Done;
|
2001-11-05 02:05:21 +03:00
|
|
|
};
|
|
|
|
|
2014-12-11 21:10:03 +03:00
|
|
|
#endif // cmCursesStringWidget_h
|