helper: command: rewrite command 'ocd_find' as COMMAND_HANDLER

The mixed use of jim commands and OpenOCD commands is error prone
due to handling of errors through JIM_xx and ERROR_yy.

Rewrite the jim command 'ocd_find' as OpenOCD command.

Change-Id: Id775bccc12840bcf95d8c19787beda5e7c3107fc
Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com>
Reviewed-on: https://review.openocd.org/c/openocd/+/7484
Reviewed-by: Tomas Vanek <vanekt@fbl.cz>
Tested-by: jenkins
This commit is contained in:
Antonio Borneo 2022-12-19 00:01:00 +01:00
parent 5f6ceebbba
commit 1ec8b83cbd
1 changed files with 10 additions and 10 deletions

View File

@ -662,19 +662,19 @@ void command_done(struct command_context *cmd_ctx)
} }
/* find full path to file */ /* find full path to file */
static int jim_find(Jim_Interp *interp, int argc, Jim_Obj *const *argv) COMMAND_HANDLER(handle_find)
{ {
if (argc != 2) if (CMD_ARGC != 1)
return JIM_ERR; return ERROR_COMMAND_SYNTAX_ERROR;
const char *file = Jim_GetString(argv[1], NULL);
char *full_path = find_file(file); char *full_path = find_file(CMD_ARGV[0]);
if (!full_path) if (!full_path)
return JIM_ERR; return ERROR_COMMAND_ARGUMENT_INVALID;
Jim_Obj *result = Jim_NewStringObj(interp, full_path, strlen(full_path));
command_print(CMD, "%s", full_path);
free(full_path); free(full_path);
Jim_SetResult(interp, result); return ERROR_OK;
return JIM_OK;
} }
COMMAND_HANDLER(handle_echo) COMMAND_HANDLER(handle_echo)
@ -1165,7 +1165,7 @@ static const struct command_registration command_builtin_handlers[] = {
{ {
.name = "ocd_find", .name = "ocd_find",
.mode = COMMAND_ANY, .mode = COMMAND_ANY,
.jim_handler = jim_find, .handler = handle_find,
.help = "find full path to file", .help = "find full path to file",
.usage = "file", .usage = "file",
}, },