mirror of
https://github.com/systemd/systemd-stable.git
synced 2024-12-27 03:21:32 +03:00
Merge pull request #13041 from poettering/firstboot-fixes
two systemd-firstboot fixes
This commit is contained in:
commit
3f127e3981
@ -87,20 +87,31 @@ static bool press_any_key(void) {
|
||||
}
|
||||
|
||||
static void print_welcome(void) {
|
||||
_cleanup_free_ char *pretty_name = NULL;
|
||||
_cleanup_free_ char *pretty_name = NULL, *ansi_color = NULL;
|
||||
static bool done = false;
|
||||
const char *pn;
|
||||
int r;
|
||||
|
||||
if (done)
|
||||
return;
|
||||
|
||||
r = parse_os_release(arg_root, "PRETTY_NAME", &pretty_name, NULL);
|
||||
r = parse_os_release(
|
||||
arg_root,
|
||||
"PRETTY_NAME", &pretty_name,
|
||||
"ANSI_COLOR", &ansi_color,
|
||||
NULL);
|
||||
if (r < 0)
|
||||
log_full_errno(r == -ENOENT ? LOG_DEBUG : LOG_WARNING, r,
|
||||
"Failed to read os-release file, ignoring: %m");
|
||||
|
||||
printf("\nWelcome to your new installation of %s!\nPlease configure a few basic system settings:\n\n",
|
||||
isempty(pretty_name) ? "Linux" : pretty_name);
|
||||
pn = isempty(pretty_name) ? "Linux" : pretty_name;
|
||||
|
||||
if (colors_enabled())
|
||||
printf("\nWelcome to your new installation of \x1B[%sm%s\x1B[0m!\n", ansi_color, pn);
|
||||
else
|
||||
printf("\nWelcome to your new installation of %s!\n", pn);
|
||||
|
||||
printf("\nPlease configure your system!\n\n");
|
||||
|
||||
press_any_key();
|
||||
|
||||
@ -219,25 +230,46 @@ static int prompt_locale(void) {
|
||||
if (r < 0)
|
||||
return log_error_errno(r, "Cannot query locales list: %m");
|
||||
|
||||
print_welcome();
|
||||
if (strv_isempty(locales))
|
||||
log_debug("No locales found, skipping locale selection.");
|
||||
else if (strv_length(locales) == 1) {
|
||||
|
||||
printf("\nAvailable Locales:\n\n");
|
||||
r = show_menu(locales, 3, 22, 60);
|
||||
if (r < 0)
|
||||
return r;
|
||||
if (streq(locales[0], SYSTEMD_DEFAULT_LOCALE))
|
||||
log_debug("Only installed locale is default locale anyway, not setting locale explicitly.");
|
||||
else {
|
||||
log_debug("Only a single locale available (%s), selecting it as default.", locales[0]);
|
||||
|
||||
putchar('\n');
|
||||
arg_locale = strdup(locales[0]);
|
||||
if (!arg_locale)
|
||||
return log_oom();
|
||||
|
||||
r = prompt_loop("Please enter system locale name or number", locales, locale_is_valid, &arg_locale);
|
||||
if (r < 0)
|
||||
return r;
|
||||
/* Not setting arg_locale_message here, since it defaults to LANG anyway */
|
||||
}
|
||||
} else {
|
||||
print_welcome();
|
||||
|
||||
if (isempty(arg_locale))
|
||||
return 0;
|
||||
printf("\nAvailable Locales:\n\n");
|
||||
r = show_menu(locales, 3, 22, 60);
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
r = prompt_loop("Please enter system message locale name or number", locales, locale_is_valid, &arg_locale_messages);
|
||||
if (r < 0)
|
||||
return r;
|
||||
putchar('\n');
|
||||
|
||||
r = prompt_loop("Please enter system locale name or number", locales, locale_is_valid, &arg_locale);
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
if (isempty(arg_locale))
|
||||
return 0;
|
||||
|
||||
r = prompt_loop("Please enter system message locale name or number", locales, locale_is_valid, &arg_locale_messages);
|
||||
if (r < 0)
|
||||
return r;
|
||||
|
||||
/* Suppress the messages setting if it's the same as the main locale anyway */
|
||||
if (streq_ptr(arg_locale, arg_locale_messages))
|
||||
arg_locale_messages = mfree(arg_locale_messages);
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user