1 /* 2 * Shell backend used for testing 3 * 4 * Copyright (c) 2018 Nordic Semiconductor ASA 5 * 6 * SPDX-License-Identifier: Apache-2.0 7 */ 8 9 #ifndef ZEPHYR_INCLUDE_SHELL_DUMMY_H_ 10 #define ZEPHYR_INCLUDE_SHELL_DUMMY_H_ 11 12 #include <zephyr/shell/shell.h> 13 14 #ifdef __cplusplus 15 extern "C" { 16 #endif 17 18 extern const struct shell_transport_api shell_dummy_transport_api; 19 20 struct shell_dummy { 21 bool initialized; 22 23 /** current number of bytes in buffer (0 if no output) */ 24 size_t len; 25 26 /** output buffer to collect shell output */ 27 char buf[CONFIG_SHELL_BACKEND_DUMMY_BUF_SIZE]; 28 }; 29 30 #define SHELL_DUMMY_DEFINE(_name) \ 31 static struct shell_dummy _name##_shell_dummy; \ 32 struct shell_transport _name = { \ 33 .api = &shell_dummy_transport_api, \ 34 .ctx = (struct shell_dummy *)&_name##_shell_dummy \ 35 } 36 37 /** 38 * @brief This function shall not be used directly. It provides pointer to shell 39 * dummy backend instance. 40 * 41 * Function returns pointer to the shell dummy instance. This instance can be 42 * next used with shell_execute_cmd function in order to test commands behavior. 43 * 44 * @returns Pointer to the shell instance. 45 */ 46 const struct shell *shell_backend_dummy_get_ptr(void); 47 48 /** 49 * @brief Returns the buffered output in the shell and resets the pointer 50 * 51 * The returned data is always followed by a nul character at position *sizep 52 * 53 * @param sh Shell pointer 54 * @param sizep Returns size of data in shell buffer 55 * @returns pointer to buffer containing shell output 56 */ 57 const char *shell_backend_dummy_get_output(const struct shell *sh, 58 size_t *sizep); 59 60 /** 61 * @brief Clears the output buffer in the shell backend. 62 * 63 * @param sh Shell pointer 64 */ 65 void shell_backend_dummy_clear_output(const struct shell *sh); 66 67 #ifdef __cplusplus 68 } 69 #endif 70 71 #endif /* ZEPHYR_INCLUDE_SHELL_DUMMY_H_ */ 72