command: the Jim interpreter can now be provided rather than created
In embedded hosts, the Jim interpreter can come from the existing context rather than be created by OpenOCD. Signed-off-by: Øyvind Harboe <oyvind.harboe@zylin.com>
This commit is contained in:
parent
63dc352876
commit
5576a6240a
|
@ -1272,7 +1272,7 @@ static const struct command_registration command_builtin_handlers[] = {
|
||||||
COMMAND_REGISTRATION_DONE
|
COMMAND_REGISTRATION_DONE
|
||||||
};
|
};
|
||||||
|
|
||||||
struct command_context* command_init(const char *startup_tcl)
|
struct command_context* command_init(const char *startup_tcl, Jim_Interp *interp)
|
||||||
{
|
{
|
||||||
struct command_context* context = malloc(sizeof(struct command_context));
|
struct command_context* context = malloc(sizeof(struct command_context));
|
||||||
const char *HostOs;
|
const char *HostOs;
|
||||||
|
@ -1284,14 +1284,18 @@ struct command_context* command_init(const char *startup_tcl)
|
||||||
context->output_handler_priv = NULL;
|
context->output_handler_priv = NULL;
|
||||||
|
|
||||||
#if !BUILD_ECOSBOARD
|
#if !BUILD_ECOSBOARD
|
||||||
|
/* Create a jim interpreter if we were not handed one */
|
||||||
|
if (interp == NULL)
|
||||||
|
{
|
||||||
Jim_InitEmbedded();
|
Jim_InitEmbedded();
|
||||||
/* Create an interpreter */
|
/* Create an interpreter */
|
||||||
context->interp = Jim_CreateInterp();
|
interp = Jim_CreateInterp();
|
||||||
/* Add all the Jim core commands */
|
/* Add all the Jim core commands */
|
||||||
Jim_RegisterCoreCommands(context->interp);
|
Jim_RegisterCoreCommands(interp);
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
context->interp = interp;
|
||||||
|
|
||||||
Jim_Interp *interp = context->interp;
|
|
||||||
#if defined(_MSC_VER)
|
#if defined(_MSC_VER)
|
||||||
/* WinXX - is generic, the forward
|
/* WinXX - is generic, the forward
|
||||||
* looking problem is this:
|
* looking problem is this:
|
||||||
|
|
|
@ -323,9 +323,11 @@ void command_set_output_handler(struct command_context* context,
|
||||||
int command_context_mode(struct command_context *context, enum command_mode mode);
|
int command_context_mode(struct command_context *context, enum command_mode mode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new command context using the startup TCL provided.
|
* Creates a new command context using the startup TCL provided and
|
||||||
|
* the existing Jim interpreter, if any. If interp == NULL, then command_init
|
||||||
|
* creates a command interpreter.
|
||||||
*/
|
*/
|
||||||
struct command_context* command_init(const char *startup_tcl);
|
struct command_context* command_init(const char *startup_tcl, Jim_Interp *interp);
|
||||||
/**
|
/**
|
||||||
* Creates a copy of an existing command context. This does not create
|
* Creates a copy of an existing command context. This does not create
|
||||||
* a deep copy of the command list, so modifications in one context will
|
* a deep copy of the command list, so modifications in one context will
|
||||||
|
|
|
@ -188,14 +188,14 @@ static const struct command_registration openocd_command_handlers[] = {
|
||||||
struct command_context *global_cmd_ctx;
|
struct command_context *global_cmd_ctx;
|
||||||
|
|
||||||
/* NB! this fn can be invoked outside this file for non PC hosted builds */
|
/* NB! this fn can be invoked outside this file for non PC hosted builds */
|
||||||
struct command_context *setup_command_handler(void)
|
struct command_context *setup_command_handler(Jim_Interp *interp)
|
||||||
{
|
{
|
||||||
log_init();
|
log_init();
|
||||||
LOG_DEBUG("log_init: complete");
|
LOG_DEBUG("log_init: complete");
|
||||||
|
|
||||||
struct command_context *cmd_ctx;
|
struct command_context *cmd_ctx;
|
||||||
|
|
||||||
global_cmd_ctx = cmd_ctx = command_init(openocd_startup_tcl);
|
global_cmd_ctx = cmd_ctx = command_init(openocd_startup_tcl, interp);
|
||||||
|
|
||||||
register_commands(cmd_ctx, NULL, openocd_command_handlers);
|
register_commands(cmd_ctx, NULL, openocd_command_handlers);
|
||||||
/* register subsystem commands */
|
/* register subsystem commands */
|
||||||
|
@ -242,7 +242,7 @@ int openocd_main(int argc, char *argv[])
|
||||||
/* initialize commandline interface */
|
/* initialize commandline interface */
|
||||||
struct command_context *cmd_ctx;
|
struct command_context *cmd_ctx;
|
||||||
|
|
||||||
cmd_ctx = setup_command_handler();
|
cmd_ctx = setup_command_handler(NULL);
|
||||||
|
|
||||||
#if BUILD_IOUTIL
|
#if BUILD_IOUTIL
|
||||||
if (ioutil_init(cmd_ctx) != ERROR_OK)
|
if (ioutil_init(cmd_ctx) != ERROR_OK)
|
||||||
|
|
Loading…
Reference in New Issue