helper/command: pass command arguments also as Jim_Obj

Some OpenOCD command gets fragment of TCL scripts as command-line
argument, fragments that will be kept and executed later on.
E.g. the command 'configure' gets the body of an OpenOCD event:
	$TARGET configure -event halted {TCL code}

These commands store the argument as a Jim_Obj and pass it to the
jimtcl interpreter when the TCL fragment has to be executed.
Using Jim_Obj as storage is relevant to let the jimtcl interpreter
to recover extra info of the TCL fragment, like the file-name and
the line-number that contain the fragment, that will be printed
out in case of run-time errors.

While converting the commands to COMMAND_HANDLER, we should avoid
storing the argument as C strings otherwise we will loose precious
info in case of run-time errors making challenging the debugging
of such TCL fragments.

Extend the struct command_invocation to contain the array that
points to the Jim_Obj of the command arguments.
This will be used while converting commands to COMMAND_HANDLER.

Change-Id: If37c5f20e9a71349f77ba1571baf1e6778e28aa5
Signed-off-by: Antonio Borneo <borneo.antonio@gmail.com>
Reviewed-on: https://review.openocd.org/c/openocd/+/8057
Tested-by: jenkins
This commit is contained in:
Antonio Borneo 2023-08-06 12:38:54 +02:00 committed by Evgeniy Naydanov
parent 350f5c3547
commit a47fae7934
3 changed files with 9 additions and 0 deletions

View File

@ -79,6 +79,8 @@ command handlers and helpers:
- @c CMD_NAME - invoked command name - @c CMD_NAME - invoked command name
- @c CMD_ARGC - the number of command arguments - @c CMD_ARGC - the number of command arguments
- @c CMD_ARGV - array of command argument strings - @c CMD_ARGV - array of command argument strings
- @c CMD_JIMTCL_ARGV - array containing the Jim_Obj equivalent of command
argument in @c CMD_ARGV.
@section helpercmdregister Command Registration @section helpercmdregister Command Registration

View File

@ -511,6 +511,7 @@ static int exec_command(Jim_Interp *interp, struct command_context *context,
.name = c->name, .name = c->name,
.argc = argc - 1, .argc = argc - 1,
.argv = words + 1, .argv = words + 1,
.jimtcl_argv = argv + 1,
}; };
cmd.output = Jim_NewEmptyStringObj(context->interp); cmd.output = Jim_NewEmptyStringObj(context->interp);

View File

@ -79,6 +79,7 @@ struct command_invocation {
const char *name; const char *name;
unsigned argc; unsigned argc;
const char **argv; const char **argv;
Jim_Obj * const *jimtcl_argv;
Jim_Obj *output; Jim_Obj *output;
}; };
@ -153,6 +154,11 @@ void *jimcmd_privdata(Jim_Cmd *cmd);
* rather than accessing the variable directly. It may be moved. * rather than accessing the variable directly. It may be moved.
*/ */
#define CMD_ARGV (cmd->argv) #define CMD_ARGV (cmd->argv)
/**
* Use this macro to access the jimtcl arguments for the command being
* handled, rather than accessing the variable directly. It may be moved.
*/
#define CMD_JIMTCL_ARGV (cmd->jimtcl_argv)
/** /**
* Use this macro to access the name of the command being handled, * Use this macro to access the name of the command being handled,
* rather than accessing the variable directly. It may be moved. * rather than accessing the variable directly. It may be moved.