Merge pull request #231 from roamboy/master

Update msh.c
This commit is contained in:
Bernard Xiong 2014-01-13 00:05:16 -08:00
commit 2970723cb0
1 changed files with 26 additions and 14 deletions

View File

@ -253,26 +253,38 @@ int msh_exec(char* cmd, rt_size_t length)
{ {
int argc; int argc;
char *argv[RT_FINSH_ARG_MAX]; char *argv[RT_FINSH_ARG_MAX];
int cmd0_size = 0;
int cmd0_size = 0;
cmd_function_t cmd_func; cmd_function_t cmd_func;
while ((cmd[cmd0_size] != ' ' && cmd[cmd0_size] != '\t') && cmd0_size < length) while(*cmd == ' ')
cmd0_size ++; {
cmd++;
/* try to get built-in command */ length--;
cmd_func = msh_get_cmd(cmd, cmd0_size); }
if (cmd_func == RT_NULL) while ((cmd[cmd0_size] != ' ' && cmd[cmd0_size] != '\t') && cmd0_size < length)
{ cmd0_size ++;
/* try to get built-in command */
if (cmd0_size == 0) return -1;
cmd_func = msh_get_cmd(cmd, cmd0_size);
if (cmd_func == RT_NULL)
{
#ifdef RT_USING_MODULE #ifdef RT_USING_MODULE
msh_exec_module(cmd, length); msh_exec_module(cmd, length);
#else #else
rt_kprintf("%s: command not found.\n", argv[0]); argv[0] = cmd;
while(*cmd != ' ')
{
if (*cmd == 0) break;
cmd++;
}
if (*cmd == ' ') *cmd = 0;
rt_kprintf("%s: command not found.\n", argv[0]);
#endif #endif
return -1; return -1;
} }
/* split arguments */ /* split arguments */
memset(argv, 0x00, sizeof(argv)); memset(argv, 0x00, sizeof(argv));
argc = msh_split(cmd, length, argv); argc = msh_split(cmd, length, argv);
if (argc == 0) return -1; if (argc == 0) return -1;