|
From: | Andreas Born |
Subject: | Re: [PATCH] create variables when exporting them |
Date: | Thu, 15 Oct 2009 21:52:00 +0200 |
User-agent: | Thunderbird 2.0.0.23 (X11/20090827) |
Here you go: ChangeLog: 2009-10-15 Andreas Born <address@hidden>* kern/env.c (grub_env_export): Create nonexistent variables before exporting.
The mixed indentation (tabs and spaces) in kern/env.c was a bit confusing. Andreas Colin Watson schrieb:
On Thu, Oct 15, 2009 at 08:40:37PM +0200, Andreas Born wrote:This patch changes grub_env_export to create variables with empty value, if necessary. This makes it possible to export variables before actually assigning them any value and is the way bash behaves.This makes sense to me (although bash is "too big and too slow" and we'll never implement anything close to all of it, this is a pretty cheap way to reduce confusion due to differences), although probably for post-1.97. A couple of nits:* kern/env.c (grub_env_export): Create inexistent variables before exporting."nonexistent"+ if (! var) + { + if (grub_env_set (name, "") != GRUB_ERR_NONE) + return grub_errno; + var = grub_env_find (name);+ }GNU brace style involves indenting the braces as well, thus: if (! var) { if (grub_env_set (name, "") != GRUB_ERR_NONE) return grub_errno; var = grub_env_find (name);}
Index: kern/env.c =================================================================== --- kern/env.c (Revision 2631) +++ kern/env.c (Arbeitskopie) @@ -170,8 +171,13 @@ struct grub_env_var *var; var = grub_env_find (name); - if (var) - var->type = GRUB_ENV_VAR_GLOBAL; + if (! var) + { + if (grub_env_set (name, "") != GRUB_ERR_NONE) + return grub_errno; + var = grub_env_find (name); + } + var->type = GRUB_ENV_VAR_GLOBAL; return GRUB_ERR_NONE; }
[Prev in Thread] | Current Thread | [Next in Thread] |