source: molecuilder/src/Menu/TextMenu.hpp@ 495a53

Last change on this file since 495a53 was 8d9984, checked in by Tillmann Crueger <crueger@…>, 15 years ago

Added full undo functioniality

  • Property mode set to 100644
File size: 1.5 KB
Line 
1/*
2 * TextMenu.h
3 *
4 * Created on: Dec 10, 2009
5 * Author: crueger
6 */
7
8#ifndef TEXTMENU_H_
9#define TEXTMENU_H_
10
11#include <list>
12#include <ostream>
13#include <string>
14
15#include "Menu/Menu.hpp"
16#include "Actions/Action.hpp"
17#include "defs.hpp"
18
19class MenuItem;
20
21/**
22 * Used to produce any kind of text menu
23 *
24 * All Items are displayed and user is prompted for a key. The item corresponding to that key is then activated.
25 */
26class TextMenu : public Menu
27{
28public:
29 class LeaveAction : public Action {
30 public:
31 LeaveAction(TextMenu*);
32 virtual ~LeaveAction();
33
34 bool canUndo();
35 bool shouldUndo();
36
37 private:
38 virtual Action::state_ptr performCall();
39 virtual Action::state_ptr performUndo(Action::state_ptr);
40 virtual Action::state_ptr performRedo(Action::state_ptr);
41
42 TextMenu* menu;
43
44 static const string nameBase;
45 };
46
47 TextMenu(ostream& _outputter, string _title, char _spacer=STD_MENU_TITLE_SPACER,int _length=STD_MENU_LENGTH);
48 virtual ~TextMenu();
49
50 virtual void addItem(MenuItem*);
51 virtual void removeItem(MenuItem*);
52 virtual void display();
53 virtual string getTitle();
54
55 /**
56 * Call doQuit if you want to return from this menu.
57 */
58 virtual void doQuit();
59 /**
60 * Check whether someone has chosen to quit
61 */
62 virtual bool hasQuit();
63
64 virtual void addDefault(MenuItem*);
65
66protected:
67 virtual void showEntry(MenuItem*);
68
69private:
70 list<MenuItem*> items;
71
72 MenuItem* defaultItem;
73
74 ostream& outputter;
75 string title;
76 char spacer;
77 int length;
78
79 bool quit;
80};
81
82#endif /* TEXTMENU_H_ */
Note: See TracBrowser for help on using the repository browser.