}
+static const FLASH char * const FLASH rc_strings[] = {
+ FSTR("OK"),
+ FSTR("disk error"),
+ FSTR("internal error"),
+ FSTR("not ready"),
+ FSTR("no file"),
+ FSTR("no path"),
+ FSTR("invalid name"),
+ FSTR("denied"),
+ FSTR("exist"),
+ FSTR("invalid object"),
+ FSTR("write protected"),
+ FSTR("invalid drive"),
+ FSTR("not enabled"),
+ FSTR("no file system"),
+ FSTR("mkfs aborted"),
+ FSTR("timeout"),
+ FSTR("locked"),
+ FSTR("not enough core"),
+ FSTR("too many open files"),
+ FSTR("invalid parameter")
+ };
+
static const FLASH char * const FLASH rc_names[] = {
FSTR("OK"),
FSTR("DISK_ERR"),
}
-void err(const char *fmt, ...)
+const FLASH char * rctostr(FRESULT rc)
{
- va_list ap;
- va_start(ap, fmt);
- printf_P(PSTR("fat %s: "), cmdname);
- vfprintf_P(stdout, fmt, ap);
- va_end(ap);
- printf_P(PSTR("\n"));
- _delay_ms(20);
- command_ret = CMD_RET_FAILURE;
+ return rc < ARRAY_SIZE(rc_strings) ? rc_strings[rc] : PSTR(" Unknown Error");
}
static void swirl(void)
static PATH_T *path_setup(char *string)
{
if (strlen(string) > PATH_MAX) {
- err(PSTR("'%s': name too long"), string);
+ cmd_error(PSTR("'%s': name too long"), string);
return NULL;
}
PATH_T *p = (PATH_T *) malloc(sizeof *p);
if (p == NULL) {
- err(PSTR("'%s': Out of Memory"), string);
+ cmd_error(PSTR("'%s': Out of Memory"), string);
return NULL;
}
p->p_path[2] = '/';
len += 1;
} else {
- err(PSTR("'%s': Out of Memory"), string);
+ cmd_error(PSTR("'%s': Out of Memory"), string);
return NULL;
}
}
char *arg;
FRESULT res = FR_OK;
- cmdname = argv[0];
-
if (argc < 2) {
arg = getenv_str(PSTR(ENV_HOME));
if (arg == NULL) {
return NULL;
}
-static int print_name_prefix(cmd_tbl_t *p)
+static int print_nameprefix(cmd_tbl_t *p)
{
cmd_tbl_t *top = get_cmd_tbl_parent(p);
return width;
}
+static int print_prefixed_name(cmd_tbl_t *p)
+{
+ int len;
+
+ len = print_nameprefix(p);
+ len += strlen_P(p->name);
+ my_puts_P(p->name);
+
+ return len;
+}
+
static void print_usage_line(cmd_tbl_t *p, int width)
{
- width -= strlen_P(p->name);
- width -= print_name_prefix(p);
+ width -= print_prefixed_name(p);
if (width < 0)
width = 0;
- my_puts_P(p->name);
print_blanks(width);
my_puts_P(PSTR(" - "));
puts_P(p->usage);
print_usage_line(cmdtp, 0);
#ifdef CONFIG_SYS_LONGHELP
my_puts_P(PSTR("Usage:\n"));
- print_name_prefix(cmdtp);
- my_puts_P(cmdtp->name);
+ print_prefixed_name(cmdtp);
my_puts_P(PSTR(" "));
if (cmdtp->help && *cmdtp->help != '\0')
#endif /* CONFIG_AUTO_COMPLETE */
+static cmd_tbl_t *cmd_invocation_ptr;
/**
* Call a command function. This should be the only route in U-Boot to call
/* If OK so far, then do the command */
if (!rc) {
+ cmd_invocation_ptr = cmdtp;
rc = cmd_call(cmdtp, flag, argc, argv);
*repeatable &= (cmdtp->flags & CTBL_RPT) != 0;
}
return 0;
}
+
+
+void cmd_error(const char *fmt, ...)
+{
+ va_list ap;
+ va_start(ap, fmt);
+ print_prefixed_name(cmd_invocation_ptr);
+ my_puts_P(PSTR(": "));
+ vfprintf_P(stdout, fmt, ap);
+ va_end(ap);
+ putchar('\n');
+ _delay_ms(20);
+ //command_ret = CMD_RET_FAILURE;
+}
*/
int cmd_process_error(cmd_tbl_t *cmdtp, int err);
+/**
+ * cmd_error() - print error message
+ *
+ * @fmt:
+ */
+void cmd_error(const char *fmt, ...);
+
/*
* Monitor Command
*