From 23273b03bb7dd46cdab919031cee47e1ccc29c7c Mon Sep 17 00:00:00 2001 From: sabetts Date: Mon, 22 Nov 2004 18:13:19 +0000 Subject: * src/actions.c (cmd_verbexec): rewritten to fix crash bug. --- ChangeLog | 8 ++++++-- src/actions.c | 20 +++++++++++++++----- 2 files changed, 21 insertions(+), 7 deletions(-) diff --git a/ChangeLog b/ChangeLog index 0beef7a..7cb8f48 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,9 +1,13 @@ -2004-11-20 Shawn Betts +2004-11-22 Shawn Betts + + * src/actions.c (cmd_verbexec): rewritten to fix crash bug. + +2004-11-20 Shawn Betts * src/actions.c (cmd_rathold): change argument order. echo parse errors. -2004-11-19 Shawn Betts +2004-11-19 Shawn Betts * src/actions.c (cmd_sfdump): properly declare i at the top of the function. diff --git a/src/actions.c b/src/actions.c index 67e24d2..0cfe727 100644 --- a/src/actions.c +++ b/src/actions.c @@ -3875,11 +3875,21 @@ cmd_frestore (int interactively, char *data) char * cmd_verbexec (int interactive, char *data) { - char msg[100]="Running "; - strncat(msg, data, 100-strlen(msg)); - - if(data) cmd_echo(interactive, msg); - return cmd_exec(interactive, data); + char *cmd; + + if (data == NULL) + cmd = get_input (MESSAGE_PROMPT_SHELL_COMMAND, exec_completions); + else + cmd = xstrdup (data); + + /* User aborted. */ + if (cmd == NULL) + return NULL; + + marked_message_printf(0, 0, " Running %s ", cmd); + spawn (cmd); + free (cmd); + return NULL; } static char * -- cgit v1.2.3