diff --git a/components/finsh/shell.c b/components/finsh/shell.c index 7b577db6b6d0a15d6a2ad3d90f3cfb80f0026ce4..20f1bdef0ff335e4c8d43040b9c9166a5b66d6ef 100644 --- a/components/finsh/shell.c +++ b/components/finsh/shell.c @@ -142,20 +142,24 @@ void finsh_set_prompt_mode(rt_uint32_t prompt_mode) shell->prompt_mode = prompt_mode; } -char finsh_getchar(void) +int finsh_getchar(void) { #ifdef RT_USING_DEVICE #ifdef RT_USING_POSIX return getchar(); #else char ch = 0; + rt_device_t device; RT_ASSERT(shell != RT_NULL); - if (shell->device == RT_NULL) + + device = shell->device; + if (device == RT_NULL) { - return -RT_ERROR; + return -1; /* EOF */ } - while (rt_device_read(shell->device, -1, &ch, 1) != 1) + + while (rt_device_read(device, -1, &ch, 1) != 1) rt_sem_take(&shell->rx_sem, RT_WAITING_FOREVER); return ch; diff --git a/components/finsh/shell.h b/components/finsh/shell.h index b671db08499d837203fa1b4bcf4992c32033af05..985d3b3fbd4db7cece6f401c098212a5064cf42e 100644 --- a/components/finsh/shell.h +++ b/components/finsh/shell.h @@ -93,7 +93,7 @@ rt_uint32_t finsh_get_echo(void); int finsh_system_init(void); void finsh_set_device(const char *device_name); const char *finsh_get_device(void); -char finsh_getchar(void); +int finsh_getchar(void); rt_uint32_t finsh_get_prompt_mode(void); void finsh_set_prompt_mode(rt_uint32_t prompt_mode);