diff options
author | Joel Sherrill <joel.sherrill@OARcorp.com> | 2009-07-22 15:17:37 +0000 |
---|---|---|
committer | Joel Sherrill <joel.sherrill@OARcorp.com> | 2009-07-22 15:17:37 +0000 |
commit | 35d09baa84f3e029646e3a2f2f0e9b348de57517 (patch) | |
tree | 9e108a9d304ab73d8e596b65dae1b83f82b6d095 /cpukit/libmisc/shell/shell_script.c | |
parent | 2009-07-22 Joel Sherrill <joel.sherrill@oarcorp.com> (diff) | |
download | rtems-35d09baa84f3e029646e3a2f2f0e9b348de57517.tar.bz2 |
2009-07-22 Joel Sherrill <joel.sherrill@oarcorp.com>
* libmisc/Makefile.am, libmisc/shell/main_chmod.c,
libmisc/shell/main_mdump.c, libmisc/shell/main_medit.c,
libmisc/shell/main_mfill.c, libmisc/shell/main_mmove.c,
libmisc/shell/main_msdosfmt.c, libmisc/shell/main_mwdump.c,
libmisc/shell/main_sleep.c, libmisc/shell/main_umask.c,
libmisc/shell/shell.h, libmisc/shell/shell_script.c,
libmisc/stringto/stringto_template.h: Convert all shell code to use
stringto.h mehods with better error checking.
* libmisc/shell/str2int.c: Removed.
Diffstat (limited to 'cpukit/libmisc/shell/shell_script.c')
-rw-r--r-- | cpukit/libmisc/shell/shell_script.c | 25 |
1 files changed, 20 insertions, 5 deletions
diff --git a/cpukit/libmisc/shell/shell_script.c b/cpukit/libmisc/shell/shell_script.c index 34be6cd0ec..c31ed051d3 100644 --- a/cpukit/libmisc/shell/shell_script.c +++ b/cpukit/libmisc/shell/shell_script.c @@ -30,6 +30,7 @@ #include <rtems.h> #include <rtems/shell.h> +#include <rtems/stringto.h> #include "internal.h" static void rtems_shell_joel_usage(void) @@ -107,6 +108,7 @@ int rtems_shell_main_joel( char **argv ) { + unsigned long tmp; int option; int sc; int verbose = 0; @@ -124,13 +126,26 @@ int rtems_shell_main_joel( case 'o': outputFile = getopt_reent.optarg; break; - case 'p': - taskPriority = - (rtems_task_priority) rtems_shell_str2int(getopt_reent.optarg); + case 'p': { + const char *s = getopt_reent.optarg; + + if ( !rtems_string_to_unsigned_long( s, &tmp, NULL, 0) ) { + printf( "Task Priority argument (%s) is not a number\n", s ); + return -1; + } + taskPriority = (rtems_task_priority) tmp; break; - case 's': - stackSize = (uint32_t) rtems_shell_str2int(getopt_reent.optarg); + } + case 's': { + const char *s = getopt_reent.optarg; + + if ( !rtems_string_to_unsigned_long( s, &tmp, NULL, 0) ) { + printf( "Stack size argument (%s) is not a number\n", s ); + return -1; + } + stackSize = (uint32_t) tmp; break; + } case 't': taskName = getopt_reent.optarg; break; |