2009-03-01 Bean <bean123ch@gmail.com>
* commands/terminal.c: Removed. * commands/handler.c: New file. * include/grub/list.h: Likewise. * include/grub/handler.h: Likewise. * kern/list.c: Likewise. * kern/handler.c: Likewise. * kern/term.h: Include header file <grub/handler.h>. (grub_term_input): Move next field to the beginning. (grub_term_output): Likewise. (grub_term_input_class): New variable. (grub_term_output_class): Likewise. (grub_term_register_input): Changed to inline function. (grub_term_register_output): Likewise. (grub_term_unregister_input): Likewise. (grub_term_unregister_output): Likewise. (grub_term_set_current_input): Likewise. (grub_term_set_current_output): Likewise. (grub_term_get_current_input): Likewise. (grub_term_get_current_output): Likewise. (grub_term_iterate_input): Removed. (grub_term_iterate_output): Likewise. * kern/term.c (grub_term_list_input): Removed. (grub_term_list_output): Likewise. (grub_term_input_class): New variable. (grub_term_output_class): Likewise. (grub_cur_term_input): Change varaible as macro. (grub_cur_term_output): Likewise. (grub_term_register_input): Removed. (grub_term_register_output): Likewise. (grub_term_unregister_input): Likewise. (grub_term_unregister_output): Likewise. (grub_term_set_current_input): Likewise. (grub_term_set_current_output): Likewise. (grub_term_iterate_input): Likewise. (grub_term_iterate_output): Likewise. (grub_term_get_current_input): Likewise. (grub_term_get_current_output): Likewise. * util/grub-editenv.c: Include header file <grub/handler.h>. (grub_term_get_current_input): Removed. (grub_term_get_current_output): Likewise. (grub_term_input_class): New variable. (grub_term_outout_class): Likewise. * util/grub-fstest.c (grub_term_get_current_input): Removed. (grub_term_get_current_output): Likewise. (grub_term_input_class): New variable. (grub_term_outout_class): Likewise. * util/grub-probe.c (grub_term_get_current_input): Removed. (grub_term_get_current_output): Likewise. (grub_term_input_class): New variable. (grub_term_outout_class): Likewise. * util/i386/pc/grub-setup.c (grub_term_get_current_input): Removed. (grub_term_get_current_output): Likewise. (grub_term_input_class): New variable. (grub_term_outout_class): Likewise. * conf/common.rmk (pkglib_MODULES): Replace terminal with handler. (terminal_mod_SOURCES): Likewise. (terminal_mod_CFLAGS): Likewise. (terminal_mod_LDFLAGS): Likewise. * conf/i386-pc.rmk (grub_emu_SOURCES): Replace terminal.c with handler.c. (kernel_img_SOURCES): Add list.c and handler.c. (kernel_img_HEADERS): Add list.h and handler.h. * conf/i386-efi.rmk (grub_emu_SOURCES): Replace terminal.c with handler.c. (kernel_mod_SOURCES): Add list.c and handler.c. (kernel_mod_HEADERS): Add list.h and handler.h. * conf/i386-coreboot.rmk (grub_emu_SOURCES): Replace terminal.c with handler.c. (kernel_elf_SOURCES): Add list.c and handler.c. (kernel_elf_HEADERS): Add list.h and handler.h. * conf/i386-ieee1275.rmk (grub_emu_SOURCES): Replace terminal.c with handler.c. (kernel_elf_SOURCES): Add list.c and handler.c. (kernel_elf_HEADERS): Add list.h and handler.h. * conf/x86_64-efi.rmk (grub_emu_SOURCES): Replace terminal.c with handler.c. (kernel_mod_SOURCES): Add list.c and handler.c. (kernel_mod_HEADERS): Add list.h and handler.h. * conf/powerpc-ieee1275.rmk (grub_emu_SOURCES): Replace terminal.c with handler.c. (kernel_elf_SOURCES): Add list.c and handler.c. (kernel_elf_HEADERS): Add list.h and handler.h.
This commit is contained in:
parent
8a31787ff5
commit
71b9f36193
28 changed files with 812 additions and 420 deletions
117
kern/term.c
117
kern/term.c
|
@ -22,14 +22,6 @@
|
|||
#include <grub/misc.h>
|
||||
#include <grub/env.h>
|
||||
|
||||
/* The list of terminals. */
|
||||
static grub_term_input_t grub_term_list_input;
|
||||
static grub_term_output_t grub_term_list_output;
|
||||
|
||||
/* The current terminal. */
|
||||
static grub_term_input_t grub_cur_term_input;
|
||||
static grub_term_output_t grub_cur_term_output;
|
||||
|
||||
/* The amount of lines counted by the pager. */
|
||||
static int grub_more_lines;
|
||||
|
||||
|
@ -39,111 +31,18 @@ static int grub_more;
|
|||
/* The current cursor state. */
|
||||
static int cursor_state = 1;
|
||||
|
||||
void
|
||||
grub_term_register_input (grub_term_input_t term)
|
||||
{
|
||||
term->next = grub_term_list_input;
|
||||
grub_term_list_input = term;
|
||||
if (! grub_cur_term_input)
|
||||
grub_term_set_current_input (term);
|
||||
}
|
||||
|
||||
void
|
||||
grub_term_register_output (grub_term_output_t term)
|
||||
{
|
||||
term->next = grub_term_list_output;
|
||||
grub_term_list_output = term;
|
||||
if (! grub_cur_term_output)
|
||||
grub_term_set_current_output (term);
|
||||
}
|
||||
|
||||
void
|
||||
grub_term_unregister_input (grub_term_input_t term)
|
||||
{
|
||||
grub_term_input_t *p, q;
|
||||
|
||||
for (p = &grub_term_list_input, q = *p; q; p = &(q->next), q = q->next)
|
||||
if (q == term)
|
||||
struct grub_handler_class grub_term_input_class =
|
||||
{
|
||||
*p = q->next;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
grub_term_unregister_output (grub_term_output_t term)
|
||||
{
|
||||
grub_term_output_t *p, q;
|
||||
.name = "terminal_input"
|
||||
};
|
||||
|
||||
for (p = &grub_term_list_output, q = *p; q; p = &(q->next), q = q->next)
|
||||
if (q == term)
|
||||
struct grub_handler_class grub_term_output_class =
|
||||
{
|
||||
*p = q->next;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
grub_term_iterate_input (int (*hook) (grub_term_input_t term))
|
||||
{
|
||||
grub_term_input_t p;
|
||||
.name = "terminal_output"
|
||||
};
|
||||
|
||||
for (p = grub_term_list_input; p; p = p->next)
|
||||
if (hook (p))
|
||||
break;
|
||||
}
|
||||
|
||||
void
|
||||
grub_term_iterate_output (int (*hook) (grub_term_output_t term))
|
||||
{
|
||||
grub_term_output_t p;
|
||||
|
||||
for (p = grub_term_list_output; p; p = p->next)
|
||||
if (hook (p))
|
||||
break;
|
||||
}
|
||||
|
||||
grub_err_t
|
||||
grub_term_set_current_input (grub_term_input_t term)
|
||||
{
|
||||
if (grub_cur_term_input && grub_cur_term_input->fini)
|
||||
if ((grub_cur_term_input->fini) () != GRUB_ERR_NONE)
|
||||
return grub_errno;
|
||||
|
||||
if (term->init)
|
||||
if ((term->init) () != GRUB_ERR_NONE)
|
||||
return grub_errno;
|
||||
|
||||
grub_cur_term_input = term;
|
||||
return GRUB_ERR_NONE;
|
||||
}
|
||||
|
||||
grub_err_t
|
||||
grub_term_set_current_output (grub_term_output_t term)
|
||||
{
|
||||
if (grub_cur_term_output && grub_cur_term_output->fini)
|
||||
if ((grub_cur_term_output->fini) () != GRUB_ERR_NONE)
|
||||
return grub_errno;
|
||||
|
||||
if (term->init)
|
||||
if ((term->init) () != GRUB_ERR_NONE)
|
||||
return grub_errno;
|
||||
|
||||
grub_cur_term_output = term;
|
||||
return GRUB_ERR_NONE;
|
||||
}
|
||||
|
||||
grub_term_input_t
|
||||
grub_term_get_current_input (void)
|
||||
{
|
||||
return grub_cur_term_input;
|
||||
}
|
||||
|
||||
grub_term_output_t
|
||||
grub_term_get_current_output (void)
|
||||
{
|
||||
return grub_cur_term_output;
|
||||
}
|
||||
#define grub_cur_term_input grub_term_get_current_input ()
|
||||
#define grub_cur_term_output grub_term_get_current_output ()
|
||||
|
||||
/* Put a Unicode character. */
|
||||
void
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue