* grub-core/normal/main.c (read_config_file): Provide config_file and

config_directory.
	* util/grub.d/41_custom.in: Use config_directoy when available.
This commit is contained in:
Vladimir 'phcoder' Serbinenko 2012-05-27 15:34:41 +02:00
parent 9da59c3275
commit 40e80b9403
3 changed files with 33 additions and 1 deletions

View file

@ -1,3 +1,9 @@
2012-05-27 Vladimir Serbinenko <phcoder@gmail.com>
* grub-core/normal/main.c (read_config_file): Provide config_file and
config_directory.
* util/grub.d/41_custom.in: Use config_directoy when available.
2012-05-27 Vladimir Serbinenko <phcoder@gmail.com>
* grub-core/fs/bfs.c (iterate_in_b_tree): Add missing NESTED_FUNC_ATTR.

View file

@ -138,6 +138,8 @@ static grub_menu_t
read_config_file (const char *config)
{
grub_file_t file;
const char *old_file, *old_dir;
char *config_dir, *ptr = 0;
auto grub_err_t getline (char **line, int cont);
grub_err_t getline (char **line, int cont __attribute__ ((unused)))
@ -176,6 +178,19 @@ read_config_file (const char *config)
if (! file)
return 0;
old_file = grub_env_get ("config_file");
old_dir = grub_env_get ("config_directory");
grub_env_set ("config_file", config);
config_dir = grub_strdup (config);
if (config_dir)
ptr = grub_strrchr (config_dir, '/');
if (ptr)
*ptr = 0;
grub_env_set ("config_directory", config_dir);
grub_env_export ("config_file");
grub_env_export ("config_directory");
while (1)
{
char *line;
@ -191,6 +206,15 @@ read_config_file (const char *config)
grub_free (line);
}
if (old_file)
grub_env_set ("config_file", old_file);
else
grub_env_unset ("config_file");
if (old_dir)
grub_env_set ("config_directory", old_dir);
else
grub_env_unset ("config_directory");
grub_file_close (file);
return newmenu;

View file

@ -1,6 +1,8 @@
#!/bin/sh
cat <<EOF
if [ -f \$prefix/custom.cfg ]; then
if [ -f \${config_directory}/custom.cfg ]; then
source \${config_directory}/custom.cfg
elif [ -z "\${config_directory}" -a -f \$prefix/custom.cfg ]; then
source \$prefix/custom.cfg;
fi
EOF