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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
|
#pragma once
/**
* \ingroup pbc
* \defgroup pbc_cmd cmd
* \brief Commands within \ref pbc
* \{
*/
#include <stddef.h>
/**
* \internal
* \brief Command handler function
*
* \param line Remaining text after command name on command line
*/
typedef void cmd_handle_t(char * line);
/**
* \internal
* \brief Command completion function
*
* \param text Current word to complete
* \param start Index in \c rl_line_buffer of cursor position
* \param end End index of \p text in \c rl_line_buffer
*
* \return Array of \c char* with suggestions. The array is terminated by a
* NULL pointer.
*/
typedef char** cmd_complete_t(const char* text, int start, int end);
/**
* \internal
* \brief Command definition struct
*/
typedef struct {
cmd_handle_t * handle; //!< Handler function (required)
const char* name; //!< Command name (required)
const char* info; //!< Command info (shown in help command) (optional = NULL)
cmd_complete_t * complete; //!< Completion function (optional = NULL)
} cmd_t;
cmd_handle_t cmd_exit;
cmd_handle_t cmd_test;
cmd_handle_t cmd_help;
cmd_handle_t cmd_reset;
cmd_handle_t cmd_ls;
cmd_handle_t cmd_send;
cmd_handle_t cmd_skip;
cmd_handle_t cmd_dump;
cmd_complete_t cmd_dump_complete;
//! Commands
static const cmd_t cmds[] = {
{
.handle = cmd_exit,
.name = "exit",
.info = "exit pbc",
},
{
.handle = cmd_help,
.name = "help",
.info = "show this help",
},
{
.handle = cmd_reset,
.name = "reset",
.info = "set game state to 'idle' for one or more puzzle modules",
},
{
.handle = cmd_skip,
.name = "skip",
.info = "set game state to 'solved' for one or more puzzle modules",
},
{
.handle = cmd_ls,
.name = "ls",
.info = "list connected puzzle modules and their state",
},
#ifdef DEBUG
{
.handle = cmd_send,
.name = "send",
.info = "[debug] send raw message",
},
{
.handle = cmd_test,
.name = "test",
.info = "[debug] send a test puzbus message",
},
{
.handle = cmd_dump,
.name = "dump",
.info = "[debug] dump sent or received messages",
.complete = cmd_dump_complete,
},
#endif
};
//! Number of commands defined in \c cmds
static const size_t cmds_length = sizeof(cmds) / sizeof(cmds[0]);
/// \}
|