2018-08-09 15:56:10 +08:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2018 Nordic Semiconductor ASA
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
#ifndef SHELL_UTILS_H__
|
|
|
|
#define SHELL_UTILS_H__
|
|
|
|
|
|
|
|
#include <zephyr.h>
|
|
|
|
#include <shell/shell.h>
|
2018-11-27 00:09:56 +08:00
|
|
|
|
2018-08-09 15:56:10 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2018-12-13 16:58:17 +08:00
|
|
|
#define SHELL_MSG_SPECIFY_SUBCOMMAND "Please specify a subcommand.\n"
|
2018-08-09 15:56:10 +08:00
|
|
|
|
|
|
|
#define SHELL_DEFAULT_TERMINAL_WIDTH (80u) /* Default PuTTY width. */
|
|
|
|
#define SHELL_DEFAULT_TERMINAL_HEIGHT (24u) /* Default PuTTY height. */
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
s32_t row_span_with_buffer_offsets_get(struct shell_multiline_cons *cons,
|
|
|
|
u16_t offset1,
|
|
|
|
u16_t offset2);
|
|
|
|
|
|
|
|
s32_t column_span_with_buffer_offsets_get(struct shell_multiline_cons *cons,
|
|
|
|
u16_t offset1,
|
|
|
|
u16_t offset2);
|
|
|
|
|
|
|
|
void shell_multiline_data_calc(struct shell_multiline_cons *cons,
|
|
|
|
u16_t buff_pos, u16_t buff_len);
|
|
|
|
|
|
|
|
static inline size_t shell_strlen(const char *str)
|
|
|
|
{
|
|
|
|
return str == NULL ? 0 : strlen(str);
|
|
|
|
}
|
|
|
|
|
|
|
|
char shell_make_argv(size_t *argc, char **argv, char *cmd, uint8_t max_argc);
|
|
|
|
|
|
|
|
/** @brief Removes pattern and following space
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void shell_pattern_remove(char *buff, u16_t *buff_len, const char *pattern);
|
|
|
|
|
2018-11-27 00:09:56 +08:00
|
|
|
/* @brief Function shall be used to search commands.
|
|
|
|
*
|
|
|
|
* It moves the pointer entry to command of static command structure. If the
|
|
|
|
* command cannot be found, the function will set entry to NULL.
|
|
|
|
*
|
|
|
|
* @param command Pointer to command which will be processed (no matter
|
|
|
|
* the root command).
|
|
|
|
* @param lvl Level of the requested command.
|
|
|
|
* @param idx Index of the requested command.
|
|
|
|
* @param entry Pointer which points to subcommand[idx] after function
|
|
|
|
* execution.
|
|
|
|
* @param st_entry Pointer to the structure where dynamic entry data can be
|
|
|
|
* stored.
|
|
|
|
*/
|
|
|
|
void shell_cmd_get(const struct shell_cmd_entry *command, size_t lvl,
|
|
|
|
size_t idx, const struct shell_static_entry **entry,
|
|
|
|
struct shell_static_entry *d_entry);
|
|
|
|
|
2018-08-09 15:56:10 +08:00
|
|
|
int shell_command_add(char *buff, u16_t *buff_len,
|
|
|
|
const char *new_cmd, const char *pattern);
|
|
|
|
|
2018-11-27 00:09:56 +08:00
|
|
|
const struct shell_cmd_entry *root_cmd_find(const char *syntax);
|
|
|
|
|
2018-08-09 15:56:10 +08:00
|
|
|
void shell_spaces_trim(char *str);
|
|
|
|
|
|
|
|
/** @brief Remove white chars from beginning and end of command buffer.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
void shell_buffer_trim(char *buff, u16_t *buff_len);
|
|
|
|
|
2018-11-27 00:09:56 +08:00
|
|
|
static inline void transport_buffer_flush(const struct shell *shell)
|
|
|
|
{
|
|
|
|
shell_fprintf_buffer_flush(shell->fprintf_ctx);
|
|
|
|
}
|
|
|
|
|
2018-08-09 15:56:10 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* SHELL_UTILS_H__ */
|