772e23dad2
Support multiple fallback entries, and provide an API to support executing default+fallback menu entries. Renamed the `terminal' menu viewer to `text'. * include/grub/normal.h (grub_normal_text_menu_viewer): New global variable declaration. (grub_menu_execute_callback): New structure declaration. (grub_menu_execute_callback_t): New typedef. (grub_menu_execute_with_fallback): New function declaration. (grub_menu_get_entry): Likewise. (grub_menu_get_timeout): Likewise. (grub_menu_set_timeout): Likewise. * normal/main.c (GRUB_MOD_INIT(normal)): Refer to new variable name. * normal/menu.c (grub_wait_after_message): Moved to `normal/menu_text.c'. (draw_border): Likewise. (print_message): Likewise. (print_entry): Likewise. (print_entries): Likewise. (grub_menu_init_page): Likewise. (get_entry_number): Likewise. (print_timeout): Likewise. (run_menu): Likewise. (grub_menu_execute_entry): Likewise. (show_text_menu): Likewise. (get_and_remove_first_entry_number): New function. (grub_menu_execute_with_fallback): Likewise. (get_entry): Renamed to ... (grub_menu_get_entry): .. this and made it global. (get_timeout): Renamed to ... (grub_menu_get_timeout): ... this and made it global. (set_timeout): Renamed to ... (grub_menu_set_timeout): ... this and made it global. (grub_normal_terminal_menu_viewer): Renamed to ... (grub_normal_text_menu_viewer): ... this. * normal/menu_text.c: New file. Extracted text-menu-specific code from normal/menu.c. * conf/i386-coreboot.rmk (grub_emu_SOURCES): Add `normal/menu_text.c'. (normal_mod_SOURCES): Likewise. * conf/i386-efi.rmk (grub_emu_SOURCES): Likewise. (normal_mod_SOURCES): Likewise. * conf/i386-ieee1275.rmk (grub_emu_SOURCES): Likewise. (normal_mod_SOURCES): Likewise. * conf/i386-pc.rmk, (grub_emu_SOURCES): Likewise. (normal_mod_SOURCES): Likewise. * conf/powerpc-ieee1275.rmk (grub_emu_SOURCES): Likewise. (normal_mod_SOURCES): Likewise. * conf/sparc64-ieee1275.rmk (grub_emu_SOURCES): Likewise. (normal_mod_SOURCES): Likewise. * conf/x86_64-efi.rmk (grub_emu_SOURCES): Likewise. (normal_mod_SOURCES): Likewise.
198 lines
6.8 KiB
C
198 lines
6.8 KiB
C
/* normal.h - prototypes for the normal mode */
|
|
/*
|
|
* GRUB -- GRand Unified Bootloader
|
|
* Copyright (C) 2002,2003,2005,2006,2007,2008,2009 Free Software Foundation, Inc.
|
|
*
|
|
* GRUB is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* GRUB is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with GRUB. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef GRUB_NORMAL_HEADER
|
|
#define GRUB_NORMAL_HEADER 1
|
|
|
|
#include <grub/setjmp.h>
|
|
#include <grub/symbol.h>
|
|
#include <grub/err.h>
|
|
#include <grub/arg.h>
|
|
#include <grub/env.h>
|
|
#include <grub/menu.h>
|
|
|
|
/* The maximum size of a command-line. */
|
|
#define GRUB_MAX_CMDLINE 1600
|
|
|
|
/* Can be run in the command-line. */
|
|
#define GRUB_COMMAND_FLAG_CMDLINE 0x1
|
|
/* Can be run in the menu. */
|
|
#define GRUB_COMMAND_FLAG_MENU 0x2
|
|
/* Can be run in both interfaces. */
|
|
#define GRUB_COMMAND_FLAG_BOTH 0x3
|
|
/* Only for the command title. */
|
|
#define GRUB_COMMAND_FLAG_TITLE 0x4
|
|
/* Don't print the command on booting. */
|
|
#define GRUB_COMMAND_FLAG_NO_ECHO 0x8
|
|
/* Pass arguments to the command without parsing options. */
|
|
#define GRUB_COMMAND_FLAG_NO_ARG_PARSE 0x10
|
|
/* Not loaded yet. Used for auto-loading. */
|
|
#define GRUB_COMMAND_FLAG_NOT_LOADED 0x20
|
|
|
|
/* The type of a completion item. */
|
|
enum grub_completion_type
|
|
{
|
|
GRUB_COMPLETION_TYPE_COMMAND,
|
|
GRUB_COMPLETION_TYPE_DEVICE,
|
|
GRUB_COMPLETION_TYPE_PARTITION,
|
|
GRUB_COMPLETION_TYPE_FILE,
|
|
GRUB_COMPLETION_TYPE_ARGUMENT
|
|
};
|
|
typedef enum grub_completion_type grub_completion_type_t;
|
|
|
|
/* The command description. */
|
|
struct grub_command
|
|
{
|
|
/* The name. */
|
|
char *name;
|
|
|
|
/* The callback function. */
|
|
grub_err_t (*func) (struct grub_arg_list *state, int argc, char **args);
|
|
|
|
/* The flags. */
|
|
unsigned flags;
|
|
|
|
/* The summary of the command usage. */
|
|
const char *summary;
|
|
|
|
/* The description of the command. */
|
|
const char *description;
|
|
|
|
/* The argument parser optionlist. */
|
|
const struct grub_arg_option *options;
|
|
|
|
/* The name of a module. Used for auto-loading. */
|
|
char *module_name;
|
|
|
|
/* The next element. */
|
|
struct grub_command *next;
|
|
};
|
|
typedef struct grub_command *grub_command_t;
|
|
|
|
/* This is used to store the names of filesystem modules for auto-loading. */
|
|
struct grub_fs_module_list
|
|
{
|
|
char *name;
|
|
struct grub_fs_module_list *next;
|
|
};
|
|
typedef struct grub_fs_module_list *grub_fs_module_list_t;
|
|
|
|
/* To exit from the normal mode. */
|
|
extern grub_jmp_buf grub_exit_env;
|
|
|
|
extern struct grub_menu_viewer grub_normal_text_menu_viewer;
|
|
|
|
/* Callback structure menu viewers can use to provide user feedback when
|
|
default entries are executed, possibly including fallback entries. */
|
|
typedef struct grub_menu_execute_callback
|
|
{
|
|
/* Called immediately before ENTRY is booted. */
|
|
void (*notify_booting) (grub_menu_entry_t entry, void *userdata);
|
|
|
|
/* Called when executing one entry has failed, and another entry, ENTRY, will
|
|
be executed as a fallback. The implementation of this function should
|
|
delay for a period of at least 2 seconds before returning in order to
|
|
allow the user time to read the information before it can be lost by
|
|
executing ENTRY. */
|
|
void (*notify_fallback) (grub_menu_entry_t entry, void *userdata);
|
|
|
|
/* Called when an entry has failed to execute and there is no remaining
|
|
fallback entry to attempt. */
|
|
void (*notify_failure) (void *userdata);
|
|
}
|
|
*grub_menu_execute_callback_t;
|
|
|
|
void grub_enter_normal_mode (const char *config);
|
|
void grub_normal_execute (const char *config, int nested);
|
|
void grub_menu_execute_with_fallback (grub_menu_t menu,
|
|
grub_menu_entry_t entry,
|
|
grub_menu_execute_callback_t callback,
|
|
void *callback_data);
|
|
void grub_menu_entry_run (grub_menu_entry_t entry);
|
|
void grub_menu_execute_entry(grub_menu_entry_t entry);
|
|
grub_menu_entry_t grub_menu_get_entry (grub_menu_t menu, int no);
|
|
int grub_menu_get_timeout (void);
|
|
void grub_menu_set_timeout (int timeout);
|
|
void grub_cmdline_run (int nested);
|
|
int grub_cmdline_get (const char *prompt, char cmdline[], unsigned max_len,
|
|
int echo_char, int readline);
|
|
grub_command_t grub_register_command (const char *name,
|
|
grub_err_t (*func) (struct grub_arg_list *state,
|
|
int argc,
|
|
char **args),
|
|
unsigned flags,
|
|
const char *summary,
|
|
const char *description,
|
|
const struct grub_arg_option *parser);
|
|
void grub_unregister_command (const char *name);
|
|
grub_command_t grub_command_find (char *cmdline);
|
|
grub_err_t grub_set_history (int newsize);
|
|
int grub_iterate_commands (int (*iterate) (grub_command_t));
|
|
int grub_command_execute (char *cmdline, int interactive);
|
|
void grub_command_init (void);
|
|
void grub_normal_init_page (void);
|
|
void grub_menu_init_page (int nested, int edit);
|
|
int grub_arg_parse (grub_command_t parser, int argc, char **argv,
|
|
struct grub_arg_list *usr, char ***args, int *argnum);
|
|
void grub_arg_show_help (grub_command_t cmd);
|
|
char *grub_normal_do_completion (char *buf, int *restore,
|
|
void (*hook) (const char *item, grub_completion_type_t type, int count));
|
|
grub_err_t grub_normal_print_device_info (const char *name);
|
|
grub_err_t grub_normal_menu_addentry (int argc, const char **args,
|
|
struct grub_script *script,
|
|
const char *sourcecode);
|
|
char *grub_env_write_color_normal (struct grub_env_var *var, const char *val);
|
|
char *grub_env_write_color_highlight (struct grub_env_var *var, const char *val);
|
|
void grub_parse_color_name_pair (grub_uint8_t *ret, const char *name);
|
|
void grub_wait_after_message (void);
|
|
|
|
#ifdef GRUB_UTIL
|
|
void grub_normal_init (void);
|
|
void grub_normal_fini (void);
|
|
void grub_hello_init (void);
|
|
void grub_hello_fini (void);
|
|
void grub_ls_init (void);
|
|
void grub_ls_fini (void);
|
|
void grub_cat_init (void);
|
|
void grub_cat_fini (void);
|
|
void grub_boot_init (void);
|
|
void grub_boot_fini (void);
|
|
void grub_cmp_init (void);
|
|
void grub_cmp_fini (void);
|
|
void grub_terminal_init (void);
|
|
void grub_terminal_fini (void);
|
|
void grub_loop_init (void);
|
|
void grub_loop_fini (void);
|
|
void grub_help_init (void);
|
|
void grub_help_fini (void);
|
|
void grub_halt_init (void);
|
|
void grub_halt_fini (void);
|
|
void grub_reboot_init (void);
|
|
void grub_reboot_fini (void);
|
|
void grub_configfile_init (void);
|
|
void grub_configfile_fini (void);
|
|
void grub_search_init (void);
|
|
void grub_search_fini (void);
|
|
void grub_test_init (void);
|
|
void grub_test_fini (void);
|
|
void grub_blocklist_init (void);
|
|
void grub_blocklist_fini (void);
|
|
#endif
|
|
|
|
#endif /* ! GRUB_NORMAL_HEADER */
|