execute menu editor commands with argument scope

This commit is contained in:
BVK Chaitanya 2010-12-08 16:43:11 +05:30
parent 24b7938b32
commit 393324be7c

View file

@ -1163,36 +1163,34 @@ clear_completions_all (struct screen *screen)
static int
run (struct screen *screen)
{
int currline = 0;
char *nextline;
char *script;
int errs_before;
grub_menu_t menu;
char *dummy[1] = { NULL };
auto grub_err_t editor_getline (char **line, int cont);
grub_err_t editor_getline (char **line, int cont __attribute__ ((unused)))
auto char * editor_getsource (void);
char * editor_getsource (void)
{
struct line *linep = screen->lines + currline;
char *p;
int i;
int size = 0;
char *source;
if (currline > screen->num_lines)
for (i = 0; i < screen->num_lines; i++)
size += screen->lines[i].len + 1;
source = grub_malloc (size + 1);
if (! source)
return NULL;
size = 0;
for (i = 0; i < screen->num_lines; i++)
{
*line = 0;
return 0;
grub_strcpy (source + size, screen->lines[i].buf);
size += screen->lines[i].len;
source[size++] = '\n';
}
/* Trim down space characters. */
for (p = linep->buf + linep->len - 1;
p >= linep->buf && grub_isspace (*p);
p--)
;
*++p = '\0';
linep->len = p - linep->buf;
for (p = linep->buf; grub_isspace (*p); p++)
;
*line = grub_strdup (p);
currline++;
return 0;
source[size] = '\0';
return source;
}
grub_cls ();
@ -1212,12 +1210,11 @@ run (struct screen *screen)
}
/* Execute the script, line for line. */
while (currline < screen->num_lines)
{
editor_getline (&nextline, 0);
if (grub_normal_parse_line (nextline, editor_getline))
break;
}
script = editor_getsource ();
if (! script)
return 0;
grub_script_execute_sourcecode (script, 0, dummy);
grub_free (script);
if (errs_before != grub_err_printed_errors)
grub_wait_after_message ();