1 /*
2 * Copyright (c) 2018 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7 #ifndef ZEPHYR_INCLUDE_SHELL_HISTORY_H_
8 #define ZEPHYR_INCLUDE_SHELL_HISTORY_H_
9
10 #include <zephyr/kernel.h>
11 #include <zephyr/sys/util.h>
12 #include <zephyr/sys/dlist.h>
13 #include <zephyr/sys/ring_buffer.h>
14 #include <stdbool.h>
15
16 #ifdef __cplusplus
17 extern "C" {
18 #endif
19
20
21 struct shell_history {
22 struct ring_buf *ring_buf;
23 sys_dlist_t list;
24 sys_dnode_t *current;
25 };
26
27 /**
28 * @brief Create shell history instance.
29 *
30 * @param _name History instance name.
31 * @param _size Memory dedicated for shell history.
32 */
33 #define Z_SHELL_HISTORY_DEFINE(_name, _size) \
34 static uint8_t __noinit __aligned(sizeof(void *)) \
35 _name##_ring_buf_data[_size]; \
36 static struct ring_buf _name##_ring_buf = \
37 { \
38 .size = _size, \
39 .buffer = _name##_ring_buf_data \
40 }; \
41 static struct shell_history _name = { \
42 .ring_buf = &_name##_ring_buf \
43 }
44
45
46 /**
47 * @brief Initialize shell history module.
48 *
49 * @param history Shell history instance.
50 */
51 void z_shell_history_init(struct shell_history *history);
52
53 /**
54 * @brief Purge shell history.
55 *
56 * Function clears whole shell command history.
57 *
58 * @param history Shell history instance.
59 *
60 */
61 void z_shell_history_purge(struct shell_history *history);
62
63 /**
64 * @brief Exit history browsing mode.
65 *
66 * @param history Shell history instance.
67 */
68 void z_shell_history_mode_exit(struct shell_history *history);
69
70 /**
71 * @brief Get next entry in shell command history.
72 *
73 * Function returns next (in given direction) stored line.
74 *
75 * @param[in] history Shell history instance.
76 * @param[in] up Direction.
77 * @param[out] dst Buffer where line is copied.
78 * @param[in,out] len Buffer size (input), amount of copied
79 * data (output).
80 * @return True if remains in history mode.
81 */
82 bool z_shell_history_get(struct shell_history *history, bool up,
83 uint8_t *dst, uint16_t *len);
84
85 /**
86 * @brief Put line into shell command history.
87 *
88 * If history is full, oldest entry (or entries) is removed.
89 *
90 * @param history Shell history instance.
91 * @param line Data.
92 * @param len Data length.
93 *
94 */
95 void z_shell_history_put(struct shell_history *history, uint8_t *line,
96 size_t len);
97
98 /**
99 * @brief Get state of shell history.
100 *
101 * @param history Shell history instance.
102 *
103 * @return True if in browsing mode.
104 */
z_shell_history_active(struct shell_history * history)105 static inline bool z_shell_history_active(struct shell_history *history)
106 {
107 return (history->current) ? true : false;
108 }
109
110 #ifdef __cplusplus
111 }
112 #endif
113
114 #endif /* ZEPHYR_INCLUDE_SHELL_HISTORY_H_ */
115