mirror of
https://github.com/systemd/systemd.git
synced 2024-10-26 08:55:40 +03:00
Merge pull request #34881 from poettering/run0-ui-tweaks
run0: various UI tweaks
This commit is contained in:
commit
6d6048b4cb
3
TODO
3
TODO
@ -162,9 +162,6 @@ Features:
|
|||||||
sd_event_add_child(), and then get rid of many more explicit sigprocmask()
|
sd_event_add_child(), and then get rid of many more explicit sigprocmask()
|
||||||
calls.
|
calls.
|
||||||
|
|
||||||
* maybe set shell.prompt.prefix credential in run0 to some warning emoji,
|
|
||||||
i.e. ⚠️ or ☢️ or ⚡ or 👊 or 🧑🔧 or so.
|
|
||||||
|
|
||||||
* introduce new structure Tpm2CombinedPolicy, that combines the various TPm2
|
* introduce new structure Tpm2CombinedPolicy, that combines the various TPm2
|
||||||
policy bits into one structure, i.e. public key info, pcr masks, pcrlock
|
policy bits into one structure, i.e. public key info, pcr masks, pcrlock
|
||||||
stuff, pin and so on. Then pass that around in tpm2_seal() and tpm2_unseal().
|
stuff, pin and so on. Then pass that around in tpm2_seal() and tpm2_unseal().
|
||||||
|
37
man/run0.xml
37
man/run0.xml
@ -207,6 +207,20 @@
|
|||||||
</listitem>
|
</listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><option>--shell-prompt-prefix=<replaceable>STRING</replaceable></option></term>
|
||||||
|
|
||||||
|
<listitem><para>Set a shell prompt prefix string. This ultimately controls the
|
||||||
|
<varname>$SHELL_PROMPT_PREFIX</varname> environment variable for the invoked program, which is
|
||||||
|
typically imported into the shell prompt. By default – if emojis are supported – a superhero emoji is
|
||||||
|
shown (🦸). This default may also be changed (or turned off) by passing the
|
||||||
|
<varname>$SYSTEMD_RUN_SHELL_PROMPT_PREFIX</varname> environment variable to <varname>run0</varname>,
|
||||||
|
see below. Set to an empty string to disable shell prompt prefixing.</para>
|
||||||
|
|
||||||
|
<xi:include href="version-info.xml" xpointer="v257"/>
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term><option>--machine=</option></term>
|
<term><option>--machine=</option></term>
|
||||||
|
|
||||||
@ -271,7 +285,30 @@
|
|||||||
|
|
||||||
<xi:include href="version-info.xml" xpointer="v256"/></listitem>
|
<xi:include href="version-info.xml" xpointer="v256"/></listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><varname>$SHELL_PROMPT_PREFIX</varname></term>
|
||||||
|
<listitem><para>By default set to the superhero emoji (if supported), but may be overriden with the
|
||||||
|
<varname>$SYSTEMD_RUN_SHELL_PROMPT_PREFIX</varname> environment variable (see below), or the
|
||||||
|
<option>--shell-prompt-prefix=</option> switch (see above).</para>
|
||||||
|
|
||||||
|
<xi:include href="version-info.xml" xpointer="v257"/></listitem>
|
||||||
|
</varlistentry>
|
||||||
</variablelist>
|
</variablelist>
|
||||||
|
|
||||||
|
<para>The following variables may be passed to <command>run0</command>:</para>
|
||||||
|
|
||||||
|
<variablelist>
|
||||||
|
<varlistentry>
|
||||||
|
<term><varname>$SYSTEMD_RUN_SHELL_PROMPT_PREFIX</varname></term>
|
||||||
|
<listitem><para>If set, overrides the default shell prompt prefix that <command>run0</command> sets
|
||||||
|
for the invoked shell (the superhero emoji). Set to an empty string to disable shell prompt
|
||||||
|
prefixing.</para>
|
||||||
|
|
||||||
|
<xi:include href="version-info.xml" xpointer="v257"/></listitem>
|
||||||
|
</varlistentry>
|
||||||
|
</variablelist>
|
||||||
|
|
||||||
</refsect1>
|
</refsect1>
|
||||||
|
|
||||||
<refsect1>
|
<refsect1>
|
||||||
|
@ -80,6 +80,7 @@ const char* special_glyph_full(SpecialGlyph code, bool force_utf) {
|
|||||||
[SPECIAL_GLYPH_YELLOW_CIRCLE] = "o",
|
[SPECIAL_GLYPH_YELLOW_CIRCLE] = "o",
|
||||||
[SPECIAL_GLYPH_BLUE_CIRCLE] = "o",
|
[SPECIAL_GLYPH_BLUE_CIRCLE] = "o",
|
||||||
[SPECIAL_GLYPH_GREEN_CIRCLE] = "o",
|
[SPECIAL_GLYPH_GREEN_CIRCLE] = "o",
|
||||||
|
[SPECIAL_GLYPH_SUPERHERO] = "S",
|
||||||
},
|
},
|
||||||
|
|
||||||
/* UTF-8 */
|
/* UTF-8 */
|
||||||
@ -149,6 +150,7 @@ const char* special_glyph_full(SpecialGlyph code, bool force_utf) {
|
|||||||
[SPECIAL_GLYPH_YELLOW_CIRCLE] = u8"🟡",
|
[SPECIAL_GLYPH_YELLOW_CIRCLE] = u8"🟡",
|
||||||
[SPECIAL_GLYPH_BLUE_CIRCLE] = u8"🔵",
|
[SPECIAL_GLYPH_BLUE_CIRCLE] = u8"🔵",
|
||||||
[SPECIAL_GLYPH_GREEN_CIRCLE] = u8"🟢",
|
[SPECIAL_GLYPH_GREEN_CIRCLE] = u8"🟢",
|
||||||
|
[SPECIAL_GLYPH_SUPERHERO] = u8"🦸",
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -55,6 +55,7 @@ typedef enum SpecialGlyph {
|
|||||||
SPECIAL_GLYPH_YELLOW_CIRCLE,
|
SPECIAL_GLYPH_YELLOW_CIRCLE,
|
||||||
SPECIAL_GLYPH_BLUE_CIRCLE,
|
SPECIAL_GLYPH_BLUE_CIRCLE,
|
||||||
SPECIAL_GLYPH_GREEN_CIRCLE,
|
SPECIAL_GLYPH_GREEN_CIRCLE,
|
||||||
|
SPECIAL_GLYPH_SUPERHERO,
|
||||||
_SPECIAL_GLYPH_MAX,
|
_SPECIAL_GLYPH_MAX,
|
||||||
_SPECIAL_GLYPH_INVALID = -EINVAL,
|
_SPECIAL_GLYPH_INVALID = -EINVAL,
|
||||||
} SpecialGlyph;
|
} SpecialGlyph;
|
||||||
|
160
src/run/run.c
160
src/run/run.c
@ -85,6 +85,7 @@ static char *arg_exec_path = NULL;
|
|||||||
static bool arg_ignore_failure = false;
|
static bool arg_ignore_failure = false;
|
||||||
static char *arg_background = NULL;
|
static char *arg_background = NULL;
|
||||||
static sd_json_format_flags_t arg_json_format_flags = SD_JSON_FORMAT_OFF;
|
static sd_json_format_flags_t arg_json_format_flags = SD_JSON_FORMAT_OFF;
|
||||||
|
static char *arg_shell_prompt_prefix = NULL;
|
||||||
|
|
||||||
STATIC_DESTRUCTOR_REGISTER(arg_description, freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_description, freep);
|
||||||
STATIC_DESTRUCTOR_REGISTER(arg_environment, strv_freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_environment, strv_freep);
|
||||||
@ -96,6 +97,7 @@ STATIC_DESTRUCTOR_REGISTER(arg_working_directory, freep);
|
|||||||
STATIC_DESTRUCTOR_REGISTER(arg_cmdline, strv_freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_cmdline, strv_freep);
|
||||||
STATIC_DESTRUCTOR_REGISTER(arg_exec_path, freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_exec_path, freep);
|
||||||
STATIC_DESTRUCTOR_REGISTER(arg_background, freep);
|
STATIC_DESTRUCTOR_REGISTER(arg_background, freep);
|
||||||
|
STATIC_DESTRUCTOR_REGISTER(arg_shell_prompt_prefix, freep);
|
||||||
|
|
||||||
static int help(void) {
|
static int help(void) {
|
||||||
_cleanup_free_ char *link = NULL;
|
_cleanup_free_ char *link = NULL;
|
||||||
@ -194,6 +196,7 @@ static int help_sudo_mode(void) {
|
|||||||
" --background=COLOR Set ANSI color for background\n"
|
" --background=COLOR Set ANSI color for background\n"
|
||||||
" --pty Request allocation of a pseudo TTY for stdio\n"
|
" --pty Request allocation of a pseudo TTY for stdio\n"
|
||||||
" --pipe Request direct pipe for stdio\n"
|
" --pipe Request direct pipe for stdio\n"
|
||||||
|
" --shell-prompt-prefix=PREFIX Set $SHELL_PROMPT_PREFIX\n"
|
||||||
"\nSee the %s for details.\n",
|
"\nSee the %s for details.\n",
|
||||||
program_invocation_short_name,
|
program_invocation_short_name,
|
||||||
ansi_highlight(),
|
ansi_highlight(),
|
||||||
@ -778,29 +781,31 @@ static int parse_argv_sudo_mode(int argc, char *argv[]) {
|
|||||||
ARG_BACKGROUND,
|
ARG_BACKGROUND,
|
||||||
ARG_PTY,
|
ARG_PTY,
|
||||||
ARG_PIPE,
|
ARG_PIPE,
|
||||||
|
ARG_SHELL_PROMPT_PREFIX,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* If invoked as "run0" binary, let's expose a more sudo-like interface. We add various extensions
|
/* If invoked as "run0" binary, let's expose a more sudo-like interface. We add various extensions
|
||||||
* though (but limit the extension to long options). */
|
* though (but limit the extension to long options). */
|
||||||
|
|
||||||
static const struct option options[] = {
|
static const struct option options[] = {
|
||||||
{ "help", no_argument, NULL, 'h' },
|
{ "help", no_argument, NULL, 'h' },
|
||||||
{ "version", no_argument, NULL, 'V' },
|
{ "version", no_argument, NULL, 'V' },
|
||||||
{ "no-ask-password", no_argument, NULL, ARG_NO_ASK_PASSWORD },
|
{ "no-ask-password", no_argument, NULL, ARG_NO_ASK_PASSWORD },
|
||||||
{ "machine", required_argument, NULL, ARG_MACHINE },
|
{ "machine", required_argument, NULL, ARG_MACHINE },
|
||||||
{ "unit", required_argument, NULL, ARG_UNIT },
|
{ "unit", required_argument, NULL, ARG_UNIT },
|
||||||
{ "property", required_argument, NULL, ARG_PROPERTY },
|
{ "property", required_argument, NULL, ARG_PROPERTY },
|
||||||
{ "description", required_argument, NULL, ARG_DESCRIPTION },
|
{ "description", required_argument, NULL, ARG_DESCRIPTION },
|
||||||
{ "slice", required_argument, NULL, ARG_SLICE },
|
{ "slice", required_argument, NULL, ARG_SLICE },
|
||||||
{ "slice-inherit", no_argument, NULL, ARG_SLICE_INHERIT },
|
{ "slice-inherit", no_argument, NULL, ARG_SLICE_INHERIT },
|
||||||
{ "user", required_argument, NULL, 'u' },
|
{ "user", required_argument, NULL, 'u' },
|
||||||
{ "group", required_argument, NULL, 'g' },
|
{ "group", required_argument, NULL, 'g' },
|
||||||
{ "nice", required_argument, NULL, ARG_NICE },
|
{ "nice", required_argument, NULL, ARG_NICE },
|
||||||
{ "chdir", required_argument, NULL, 'D' },
|
{ "chdir", required_argument, NULL, 'D' },
|
||||||
{ "setenv", required_argument, NULL, ARG_SETENV },
|
{ "setenv", required_argument, NULL, ARG_SETENV },
|
||||||
{ "background", required_argument, NULL, ARG_BACKGROUND },
|
{ "background", required_argument, NULL, ARG_BACKGROUND },
|
||||||
{ "pty", no_argument, NULL, ARG_PTY },
|
{ "pty", no_argument, NULL, ARG_PTY },
|
||||||
{ "pipe", no_argument, NULL, ARG_PIPE },
|
{ "pipe", no_argument, NULL, ARG_PIPE },
|
||||||
|
{ "shell-prompt-prefix", required_argument, NULL, ARG_SHELL_PROMPT_PREFIX },
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -907,6 +912,12 @@ static int parse_argv_sudo_mode(int argc, char *argv[]) {
|
|||||||
arg_stdio = ARG_STDIO_DIRECT;
|
arg_stdio = ARG_STDIO_DIRECT;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case ARG_SHELL_PROMPT_PREFIX:
|
||||||
|
r = free_and_strdup_warn(&arg_shell_prompt_prefix, optarg);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
break;
|
||||||
|
|
||||||
case '?':
|
case '?':
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
@ -1019,6 +1030,25 @@ static int parse_argv_sudo_mode(int argc, char *argv[]) {
|
|||||||
log_debug_errno(r, "Unable to get terminal background color, not tinting background: %m");
|
log_debug_errno(r, "Unable to get terminal background color, not tinting background: %m");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!arg_shell_prompt_prefix) {
|
||||||
|
const char *e = secure_getenv("SYSTEMD_RUN_SHELL_PROMPT_PREFIX");
|
||||||
|
if (e) {
|
||||||
|
arg_shell_prompt_prefix = strdup(e);
|
||||||
|
if (!arg_shell_prompt_prefix)
|
||||||
|
return log_oom();
|
||||||
|
} else if (emoji_enabled()) {
|
||||||
|
arg_shell_prompt_prefix = strjoin(special_glyph(SPECIAL_GLYPH_SUPERHERO), " ");
|
||||||
|
if (!arg_shell_prompt_prefix)
|
||||||
|
return log_oom();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isempty(arg_shell_prompt_prefix)) {
|
||||||
|
r = strv_env_assign(&arg_environment, "SHELL_PROMPT_PREFIX", arg_shell_prompt_prefix);
|
||||||
|
if (r < 0)
|
||||||
|
return log_error_errno(r, "Failed to set $SHELL_PROMPT_PREFIX environment variable: %m");
|
||||||
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1371,70 +1401,38 @@ static int transient_timer_set_properties(sd_bus_message *m) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int make_unit_name(sd_bus *bus, UnitType t, char **ret) {
|
static int make_unit_name(UnitType t, char **ret) {
|
||||||
unsigned soft_reboots_count = 0;
|
|
||||||
const char *unique, *id;
|
|
||||||
char *p;
|
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(bus);
|
|
||||||
assert(t >= 0);
|
assert(t >= 0);
|
||||||
assert(t < _UNIT_TYPE_MAX);
|
assert(t < _UNIT_TYPE_MAX);
|
||||||
assert(ret);
|
assert(ret);
|
||||||
|
|
||||||
r = sd_bus_get_unique_name(bus, &unique);
|
/* Preferably use our PID + pidfd ID as identifier, if available. It's a boot time unique identifier
|
||||||
|
* managed by the kernel. Unfortunately only new kernels support this, hence we keep some fallback
|
||||||
|
* logic in place. */
|
||||||
|
|
||||||
|
_cleanup_(pidref_done) PidRef self = PIDREF_NULL;
|
||||||
|
r = pidref_set_self(&self);
|
||||||
|
if (r < 0)
|
||||||
|
return log_error_errno(r, "Failed to get reference to my own process: %m");
|
||||||
|
|
||||||
|
r = pidref_acquire_pidfd_id(&self);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
|
log_debug_errno(r, "Failed to acquire pidfd ID of myself, defaulting to randomized unit name: %m");
|
||||||
|
|
||||||
|
/* We couldn't get the pidfd id. In that case, just pick a random uuid as name */
|
||||||
sd_id128_t rnd;
|
sd_id128_t rnd;
|
||||||
|
|
||||||
/* We couldn't get the unique name, which is a pretty
|
|
||||||
* common case if we are connected to systemd
|
|
||||||
* directly. In that case, just pick a random uuid as
|
|
||||||
* name */
|
|
||||||
|
|
||||||
r = sd_id128_randomize(&rnd);
|
r = sd_id128_randomize(&rnd);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to generate random run unit name: %m");
|
return log_error_errno(r, "Failed to generate random run unit name: %m");
|
||||||
|
|
||||||
if (asprintf(ret, "run-r" SD_ID128_FORMAT_STR ".%s", SD_ID128_FORMAT_VAL(rnd), unit_type_to_string(t)) < 0)
|
r = asprintf(ret, "run-r" SD_ID128_FORMAT_STR ".%s", SD_ID128_FORMAT_VAL(rnd), unit_type_to_string(t));
|
||||||
return log_oom();
|
} else
|
||||||
|
r = asprintf(ret, "run-p" PID_FMT "-i%" PRIu64 ".%s", self.pid, self.fd_id, unit_type_to_string(t));
|
||||||
|
if (r < 0)
|
||||||
|
return log_oom();
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* We managed to get the unique name, then let's use that to name our transient units. */
|
|
||||||
|
|
||||||
id = startswith(unique, ":1."); /* let' strip the usual prefix */
|
|
||||||
if (!id)
|
|
||||||
id = startswith(unique, ":"); /* the spec only requires things to start with a colon, hence
|
|
||||||
* let's add a generic fallback for that. */
|
|
||||||
if (!id)
|
|
||||||
return log_error_errno(SYNTHETIC_ERRNO(EINVAL),
|
|
||||||
"Unique name %s has unexpected format.",
|
|
||||||
unique);
|
|
||||||
|
|
||||||
/* The unique D-Bus names are actually unique per D-Bus instance, so on soft-reboot they will wrap
|
|
||||||
* and start over since the D-Bus broker is restarted. If there's a failed unit left behind that
|
|
||||||
* hasn't been garbage collected, we'll conflict. Append the soft-reboot counter to avoid clashing. */
|
|
||||||
if (arg_runtime_scope == RUNTIME_SCOPE_SYSTEM) {
|
|
||||||
_cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
|
|
||||||
r = bus_get_property_trivial(
|
|
||||||
bus, bus_systemd_mgr, "SoftRebootsCount", &error, 'u', &soft_reboots_count);
|
|
||||||
if (r < 0)
|
|
||||||
log_debug_errno(r,
|
|
||||||
"Failed to get SoftRebootsCount property, ignoring: %s",
|
|
||||||
bus_error_message(&error, r));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (soft_reboots_count > 0) {
|
|
||||||
if (asprintf(&p, "run-u%s-s%u.%s", id, soft_reboots_count, unit_type_to_string(t)) < 0)
|
|
||||||
return log_oom();
|
|
||||||
} else {
|
|
||||||
p = strjoin("run-u", id, ".", unit_type_to_string(t));
|
|
||||||
if (!p)
|
|
||||||
return log_oom();
|
|
||||||
}
|
|
||||||
|
|
||||||
*ret = p;
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1844,7 +1842,7 @@ static int start_transient_service(sd_bus *bus) {
|
|||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to mangle unit name: %m");
|
return log_error_errno(r, "Failed to mangle unit name: %m");
|
||||||
} else {
|
} else {
|
||||||
r = make_unit_name(bus, UNIT_SERVICE, &service);
|
r = make_unit_name(UNIT_SERVICE, &service);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
@ -2059,7 +2057,7 @@ static int start_transient_scope(sd_bus *bus) {
|
|||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_error_errno(r, "Failed to mangle scope name: %m");
|
return log_error_errno(r, "Failed to mangle scope name: %m");
|
||||||
} else {
|
} else {
|
||||||
r = make_unit_name(bus, UNIT_SCOPE, &scope);
|
r = make_unit_name(UNIT_SCOPE, &scope);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
@ -2358,7 +2356,7 @@ static int start_transient_trigger(sd_bus *bus, const char *suffix) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
r = make_unit_name(bus, UNIT_SERVICE, &service);
|
r = make_unit_name(UNIT_SERVICE, &service);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
|
|
||||||
@ -2437,16 +2435,30 @@ static int run(int argc, char* argv[]) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!arg_description) {
|
if (!arg_description) {
|
||||||
char *t;
|
_cleanup_free_ char *t = NULL;
|
||||||
|
|
||||||
if (strv_isempty(arg_cmdline))
|
if (strv_isempty(arg_cmdline))
|
||||||
t = strdup(arg_unit);
|
t = strdup(arg_unit);
|
||||||
else
|
else if (startswith(arg_cmdline[0], "-")) {
|
||||||
|
/* Drop the login shell marker from the command line when generating the description,
|
||||||
|
* in order to minimize user confusion. */
|
||||||
|
_cleanup_strv_free_ char **l = strv_copy(arg_cmdline);
|
||||||
|
if (!l)
|
||||||
|
return log_oom();
|
||||||
|
|
||||||
|
r = free_and_strdup_warn(l + 0, l[0] + 1);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
t = quote_command_line(l, SHELL_ESCAPE_EMPTY);
|
||||||
|
} else
|
||||||
t = quote_command_line(arg_cmdline, SHELL_ESCAPE_EMPTY);
|
t = quote_command_line(arg_cmdline, SHELL_ESCAPE_EMPTY);
|
||||||
if (!t)
|
if (!t)
|
||||||
return log_oom();
|
return log_oom();
|
||||||
|
|
||||||
free_and_replace(arg_description, t);
|
arg_description = strjoin("[", program_invocation_short_name, "] ", t);
|
||||||
|
if (!arg_description)
|
||||||
|
return log_oom();
|
||||||
}
|
}
|
||||||
|
|
||||||
/* For backward compatibility reasons env var expansion is disabled by default for scopes, and
|
/* For backward compatibility reasons env var expansion is disabled by default for scopes, and
|
||||||
|
@ -82,7 +82,7 @@ TEST(keymaps) {
|
|||||||
|
|
||||||
#define dump_glyph(x) log_info(STRINGIFY(x) ": %s", special_glyph(x))
|
#define dump_glyph(x) log_info(STRINGIFY(x) ": %s", special_glyph(x))
|
||||||
TEST(dump_special_glyphs) {
|
TEST(dump_special_glyphs) {
|
||||||
assert_cc(SPECIAL_GLYPH_GREEN_CIRCLE + 1 == _SPECIAL_GLYPH_MAX);
|
assert_cc(SPECIAL_GLYPH_SUPERHERO + 1 == _SPECIAL_GLYPH_MAX);
|
||||||
|
|
||||||
log_info("is_locale_utf8: %s", yes_no(is_locale_utf8()));
|
log_info("is_locale_utf8: %s", yes_no(is_locale_utf8()));
|
||||||
|
|
||||||
@ -133,6 +133,7 @@ TEST(dump_special_glyphs) {
|
|||||||
dump_glyph(SPECIAL_GLYPH_YELLOW_CIRCLE);
|
dump_glyph(SPECIAL_GLYPH_YELLOW_CIRCLE);
|
||||||
dump_glyph(SPECIAL_GLYPH_BLUE_CIRCLE);
|
dump_glyph(SPECIAL_GLYPH_BLUE_CIRCLE);
|
||||||
dump_glyph(SPECIAL_GLYPH_GREEN_CIRCLE);
|
dump_glyph(SPECIAL_GLYPH_GREEN_CIRCLE);
|
||||||
|
dump_glyph(SPECIAL_GLYPH_SUPERHERO);
|
||||||
}
|
}
|
||||||
|
|
||||||
DEFINE_TEST_MAIN(LOG_INFO);
|
DEFINE_TEST_MAIN(LOG_INFO);
|
||||||
|
Loading…
Reference in New Issue
Block a user