More shell enhancements.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/trunk@9285 35acf78f-673a-0410-8e92-d51de3d6d3f4master
parent
de50e8fae5
commit
0aabb7e5ad
|
@ -135,6 +135,9 @@ static bool is_histbuff_space(ShellHistory *shp, int length) {
|
||||||
|
|
||||||
static void save_history(ShellHistory *shp, char *line, int length) {
|
static void save_history(ShellHistory *shp, char *line, int length) {
|
||||||
|
|
||||||
|
if (shp == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
if (length > shp->sh_size - 2)
|
if (length > shp->sh_size - 2)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -172,6 +175,9 @@ static void save_history(ShellHistory *shp, char *line, int length) {
|
||||||
static int get_history(ShellHistory *shp, char *line, int dir) {
|
static int get_history(ShellHistory *shp, char *line, int dir) {
|
||||||
int count=0;
|
int count=0;
|
||||||
|
|
||||||
|
if (shp == NULL)
|
||||||
|
return -1;
|
||||||
|
|
||||||
/* Count the number of lines saved in the buffer */
|
/* Count the number of lines saved in the buffer */
|
||||||
int idx = shp->sh_beg;
|
int idx = shp->sh_beg;
|
||||||
while (idx != shp->sh_end) {
|
while (idx != shp->sh_end) {
|
||||||
|
@ -332,11 +338,25 @@ THD_FUNCTION(shellThread, p) {
|
||||||
char *lp, *cmd, *tokp, line[SHELL_MAX_LINE_LENGTH];
|
char *lp, *cmd, *tokp, line[SHELL_MAX_LINE_LENGTH];
|
||||||
char *args[SHELL_MAX_ARGUMENTS + 1];
|
char *args[SHELL_MAX_ARGUMENTS + 1];
|
||||||
|
|
||||||
|
#if SHELL_USE_HISTORY == TRUE
|
||||||
|
*(scfg->sc_histbuf) = 0;
|
||||||
|
ShellHistory hist = {
|
||||||
|
scfg->sc_histbuf,
|
||||||
|
scfg->sc_histsize,
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
0
|
||||||
|
};
|
||||||
|
ShellHistory *shp = &hist;
|
||||||
|
#else
|
||||||
|
ShellHistory *shp = NULL;
|
||||||
|
#endif
|
||||||
|
|
||||||
chprintf(chp, SHELL_NEWLINE_STR);
|
chprintf(chp, SHELL_NEWLINE_STR);
|
||||||
chprintf(chp, "ChibiOS/RT Shell"SHELL_NEWLINE_STR);
|
chprintf(chp, "ChibiOS/RT Shell"SHELL_NEWLINE_STR);
|
||||||
while (true) {
|
while (true) {
|
||||||
chprintf(chp, SHELL_PROMPT_STR);
|
chprintf(chp, SHELL_PROMPT_STR);
|
||||||
if (shellGetLine(scfg, line, sizeof(line))) {
|
if (shellGetLine(scfg, line, sizeof(line), shp)) {
|
||||||
#if (SHELL_CMD_EXIT_ENABLED == TRUE) && !defined(_CHIBIOS_NIL_)
|
#if (SHELL_CMD_EXIT_ENABLED == TRUE) && !defined(_CHIBIOS_NIL_)
|
||||||
chprintf(chp, SHELL_NEWLINE_STR);
|
chprintf(chp, SHELL_NEWLINE_STR);
|
||||||
chprintf(chp, "logout");
|
chprintf(chp, "logout");
|
||||||
|
@ -424,22 +444,23 @@ void shellExit(msg_t msg) {
|
||||||
* @param[in] scfg pointer to a @p ShellConfig object
|
* @param[in] scfg pointer to a @p ShellConfig object
|
||||||
* @param[in] line pointer to the line buffer
|
* @param[in] line pointer to the line buffer
|
||||||
* @param[in] size buffer maximum length
|
* @param[in] size buffer maximum length
|
||||||
|
* @param[in] shp pointer to a @p ShellHistory object or NULL
|
||||||
* @return The operation status.
|
* @return The operation status.
|
||||||
* @retval true the channel was reset or CTRL-D pressed.
|
* @retval true the channel was reset or CTRL-D pressed.
|
||||||
* @retval false operation successful.
|
* @retval false operation successful.
|
||||||
*
|
*
|
||||||
* @api
|
* @api
|
||||||
*/
|
*/
|
||||||
bool shellGetLine(ShellConfig *scfg, char *line, unsigned size) {
|
bool shellGetLine(ShellConfig *scfg, char *line, unsigned size, ShellHistory *shp) {
|
||||||
char *p = line;
|
char *p = line;
|
||||||
BaseSequentialStream *chp = scfg->sc_channel;
|
BaseSequentialStream *chp = scfg->sc_channel;
|
||||||
#if (SHELL_USE_ESC_SEQ == TRUE)
|
#if SHELL_USE_ESC_SEQ == TRUE
|
||||||
bool escape = false;
|
bool escape = false;
|
||||||
bool bracket = false;
|
bool bracket = false;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if (SHELL_USE_HISTORY == TRUE)
|
#if SHELL_USE_HISTORY != TRUE
|
||||||
ShellHistory *shp = scfg->sc_history;
|
(void) shp;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
while (true) {
|
while (true) {
|
||||||
|
@ -510,9 +531,7 @@ bool shellGetLine(ShellConfig *scfg, char *line, unsigned size) {
|
||||||
if (c == '\r') {
|
if (c == '\r') {
|
||||||
chprintf(chp, SHELL_NEWLINE_STR);
|
chprintf(chp, SHELL_NEWLINE_STR);
|
||||||
#if SHELL_USE_HISTORY == TRUE
|
#if SHELL_USE_HISTORY == TRUE
|
||||||
if (shp != NULL) {
|
save_history(shp, line, p - line);
|
||||||
save_history(shp, line, p - line);
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
*p = 0;
|
*p = 0;
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -148,8 +148,10 @@ typedef struct {
|
||||||
const ShellCommand *sc_commands; /**< @brief Shell extra commands
|
const ShellCommand *sc_commands; /**< @brief Shell extra commands
|
||||||
table. */
|
table. */
|
||||||
#if (SHELL_USE_HISTORY == TRUE) || defined(__DOXYGEN__)
|
#if (SHELL_USE_HISTORY == TRUE) || defined(__DOXYGEN__)
|
||||||
ShellHistory *sc_history; /**< @brief Shell command history
|
char *sc_histbuf; /**< @brief Shell command history
|
||||||
buffer. */
|
buffer. */
|
||||||
|
const int sc_histsize; /**< @brief Shell history buffer
|
||||||
|
size. */
|
||||||
#endif
|
#endif
|
||||||
#if (SHELL_USE_COMPLETION == TRUE) || defined(__DOXYGEN__)
|
#if (SHELL_USE_COMPLETION == TRUE) || defined(__DOXYGEN__)
|
||||||
char **sc_completion; /**< @brief Shell command completion
|
char **sc_completion; /**< @brief Shell command completion
|
||||||
|
@ -207,7 +209,7 @@ extern "C" {
|
||||||
void shellInit(void);
|
void shellInit(void);
|
||||||
THD_FUNCTION(shellThread, p);
|
THD_FUNCTION(shellThread, p);
|
||||||
void shellExit(msg_t msg);
|
void shellExit(msg_t msg);
|
||||||
bool shellGetLine(ShellConfig *scfg, char *line, unsigned size);
|
bool shellGetLine(ShellConfig *scfg, char *line, unsigned size, ShellHistory *shp);
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue