OpenTTD Source 20250522-master-g467f832c2f
console_internal.h
Go to the documentation of this file.
1/*
2 * This file is part of OpenTTD.
3 * 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.
4 * 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.
5 * 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/>.
6 */
7
10#ifndef CONSOLE_INTERNAL_H
11#define CONSOLE_INTERNAL_H
12
13#include "gfx_type.h"
14
15static const uint ICON_CMDLN_SIZE = 1024;
16
23
32using IConsoleCmdProc = bool(std::span<std::string_view>);
33using IConsoleHook = ConsoleHookResult(bool);
35 IConsoleCmd(const std::string &name, IConsoleCmdProc *proc, IConsoleHook *hook) : name(name), proc(proc), hook(hook) {}
36
37 std::string name;
39 IConsoleHook *hook;
40};
41
55 IConsoleAlias(const std::string &name, std::string_view cmdline) : name(name), cmdline(cmdline) {}
56
57 std::string name;
58 std::string cmdline;
59};
60
62{
63 typedef std::map<std::string, IConsoleCmd> CommandList;
64 typedef std::map<std::string, IConsoleAlias> AliasList;
65
66 /* console parser */
67 static CommandList &Commands();
68 static AliasList &Aliases();
69
70 /* Commands */
71 static void CmdRegister(const std::string &name, IConsoleCmdProc *proc, IConsoleHook *hook = nullptr);
72 static IConsoleCmd *CmdGet(const std::string &name);
73 static void AliasRegister(const std::string &name, std::string_view cmd);
74 static IConsoleAlias *AliasGet(const std::string &name);
75};
76
77/* console functions */
78void IConsoleClearBuffer();
79
80/* console std lib (register ingame commands/aliases) */
81void IConsoleStdLibRegister();
82
83void IConsoleGUIInit();
84void IConsoleGUIFree();
85void IConsoleGUIPrint(TextColour colour_code, const std::string &string);
86
87#endif /* CONSOLE_INTERNAL_H */
Commands
List of commands.
ConsoleHookResult
Return values of console hooks (IConsoleHook).
@ CHR_HIDE
Hide the existence of the command.
@ CHR_DISALLOW
Disallow command execution.
@ CHR_ALLOW
Allow command execution.
bool(std::span< std::string_view >) IConsoleCmdProc
–Commands– Commands are commands, or functions.
void IConsoleGUIPrint(TextColour colour_code, const std::string &string)
Handle the printing of text entered into the console or redirected there by any other means.
static const uint ICON_CMDLN_SIZE
maximum length of a typed in command
Types related to the graphics and/or input devices.
TextColour
Colour of the strings, see _string_colourmap in table/string_colours.h or docs/ottd-colourtext-palett...
Definition gfx_type.h:302
–Aliases– Aliases are like shortcuts for complex functions, variable assignments, etc.
std::string cmdline
command(s) that is/are being aliased
std::string name
name of the alias
IConsoleCmdProc * proc
process executed when command is typed
IConsoleHook * hook
any special trigger action that needs executing
std::string name
name of command
static void AliasRegister(const std::string &name, std::string_view cmd)
Register a an alias for an already existing command in the console.
Definition console.cpp:159
static IConsoleAlias * AliasGet(const std::string &name)
Find the alias pointed to by its string.
Definition console.cpp:170
static void CmdRegister(const std::string &name, IConsoleCmdProc *proc, IConsoleHook *hook=nullptr)
Register a new command to be used in the console.
Definition console.cpp:137
static IConsoleCmd * CmdGet(const std::string &name)
Find the command pointed to by its string.
Definition console.cpp:147