From: Michael Brown Date: Wed, 23 Mar 2011 10:08:16 +0000 (+0000) Subject: [settings] Fix setting expansion X-Git-Tag: v1.20.1~2204 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b36882be34d13b585a61b58859d57f3c591dfb98;p=thirdparty%2Fipxe.git [settings] Fix setting expansion Commit 5fbd020 ("[settings] Display canonical setting name in output of "show" command") introduced a regression causing all setting expansions (e.g. "${net0/mac}") to expand to an empty string. Fix by returning the formatted value length from fetchf_named_setting(), as expected by the caller. Signed-off-by: Michael Brown --- diff --git a/src/core/settings.c b/src/core/settings.c index acd093f26..d498db69b 100644 --- a/src/core/settings.c +++ b/src/core/settings.c @@ -1123,6 +1123,7 @@ int fetchf_named_setting ( const char *name, struct setting setting; struct settings *origin; char tmp_name[ strlen ( name ) + 1 ]; + int len; int rc; /* Parse setting name */ @@ -1131,16 +1132,16 @@ int fetchf_named_setting ( const char *name, return rc; /* Fetch setting */ - if ( ( rc = fetchf_setting ( settings, &setting, value_buf, + if ( ( len = fetchf_setting ( settings, &setting, value_buf, value_len ) ) < 0 ) - return rc; + return len; /* Construct setting name */ origin = fetch_setting_origin ( settings, &setting ); assert ( origin != NULL ); setting_name ( origin, &setting, name_buf, name_len ); - return 0; + return len; } /******************************************************************************