1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
/* $Id$ */
/*
* This file is part of OpenTTD.
* OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
* OpenTTD 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 General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
*/
/** @file hotkeys.h %Hotkey related functions. */
#ifndef HOTKEYS_H
#define HOTKEYS_H
#include "core/smallvec_type.hpp"
#include "gfx_type.h"
/**
* All data for a single hotkey. The name (for saving/loading a configfile),
* a list of keycodes and a number to help identifying this hotkey.
*/
struct Hotkey {
Hotkey(uint16 default_keycode, const char *name, int num);
Hotkey(const uint16 *default_keycodes, const char *name, int num);
void AddKeycode(uint16 keycode);
const char *name;
int num;
SmallVector<uint16, 1> keycodes;
};
#define HOTKEY_LIST_END Hotkey((uint16)0, NULL, -1)
struct IniFile;
/**
* List of hotkeys for a window.
*/
struct HotkeyList {
HotkeyList(const char *ini_group, Hotkey *items);
~HotkeyList();
void Load(IniFile *ini);
void Save(IniFile *ini) const;
int CheckMatch(uint16 keycode, bool global_only = false) const;
private:
const char *ini_group;
Hotkey *items;
/**
* Dummy private copy constructor to prevent compilers from
* copying the structure, which fails due to _hotkey_lists.
*/
HotkeyList(const HotkeyList &other);
};
bool IsQuitKey(uint16 keycode);
void LoadHotkeysFromConfig();
void SaveHotkeysToConfig();
void HandleGlobalHotkeys(uint16 key, uint16 keycode);
#endif /* HOTKEYS_H */
|