diff --git a/nshlib/Kconfig b/nshlib/Kconfig index c3306e07b..a1f281032 100644 --- a/nshlib/Kconfig +++ b/nshlib/Kconfig @@ -359,6 +359,10 @@ config NSH_DISABLE_EXIT bool "Disable exit" default DEFAULT_SMALL && !NSH_TELNET +config NSH_DISABLE_EXPR + bool "Disable expr" + default DEFAULT_SMALL + config NSH_DISABLE_EXPORT bool "Disable export" default DEFAULT_SMALL diff --git a/nshlib/nsh_command.c b/nshlib/nsh_command.c index cb0420af5..ea3023c3a 100644 --- a/nshlib/nsh_command.c +++ b/nshlib/nsh_command.c @@ -26,6 +26,7 @@ #include #include +#include #ifdef CONFIG_NSH_BUILTIN_APPS # include @@ -91,6 +92,10 @@ static int cmd_false(FAR struct nsh_vtbl_s *vtbl, int argc, static int cmd_exit(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv); #endif +#ifndef CONFIG_NSH_DISABLE_EXPR +static int cmd_expr(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv); +#endif + static int cmd_unrecognized(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv); @@ -226,6 +231,11 @@ static const struct cmdmap_s g_cmdmap[] = CMD_MAP("exit", cmd_exit, 1, 1, NULL), #endif +#ifndef CONFIG_NSH_DISABLE_EXPR + CMD_MAP("expr", cmd_expr, 4, 4, + " "), +#endif + #ifndef CONFIG_NSH_DISABLE_EXPORT CMD_MAP("export", cmd_export, 2, 3, "[ []]"), #endif @@ -1091,6 +1101,74 @@ static int cmd_exit(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv) } #endif +#ifndef CONFIG_NSH_DISABLE_EXPR +static int cmd_expr(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv) +{ + int operand1; + int operand2; + int result; + FAR char *endptr; + + if (argc != 4) + { + nsh_output(vtbl, "Usage: %s \n", + argv[0]); + return ERROR; + } + + operand1 = strtol(argv[1], &endptr, 0); + if (*endptr != '\0') + { + nsh_output(vtbl, "operand1 invalid\n"); + return ERROR; + } + + operand2 = strtol(argv[3], &endptr, 0); + if (*endptr != '\0') + { + nsh_output(vtbl, "operand2 invalid\n"); + return ERROR; + } + + switch (argv[2][0]) + { + case '+': + result = operand1 + operand2; + break; + case '-': + result = operand1 - operand2; + break; + case '*': + result = operand1 * operand2; + break; + case '/': + if (operand2 == 0) + { + nsh_output(vtbl, "operand2 invalid\n"); + return ERROR; + } + + result = operand1 / operand2; + break; + case '%': + if (operand2 == 0) + { + nsh_output(vtbl, "operand2 invalid\n"); + return ERROR; + } + + result = operand1 % operand2; + break; + default: + nsh_output(vtbl, "Unknown operator\n"); + return ERROR; + } + + nsh_output(vtbl, "%d\n", result); + return OK; +} +#endif + /**************************************************************************** * Public Functions ****************************************************************************/