1
0
mirror of https://github.com/systemd/systemd.git synced 2025-01-05 13:18:06 +03:00

escape: add --instance option

Suggested by @keszybz in #4522.
This commit is contained in:
Lucas Werkmeister 2016-10-30 23:49:15 +01:00
parent e563e2534c
commit d936cddcb5
2 changed files with 38 additions and 3 deletions

View File

@ -80,7 +80,8 @@
<option>--unescape</option>, expects instantiated unit names <option>--unescape</option>, expects instantiated unit names
for this template and extracts and unescapes just the instance for this template and extracts and unescapes just the instance
part. May not be used in conjunction with part. May not be used in conjunction with
<option>--suffix=</option> or <option>--suffix=</option>,
<option>--instance</option> or
<option>--mangle</option>.</para></listitem> <option>--mangle</option>.</para></listitem>
</varlistentry> </varlistentry>
@ -118,6 +119,19 @@
<option>--unescape</option>.</para></listitem> <option>--unescape</option>.</para></listitem>
</varlistentry> </varlistentry>
<varlistentry>
<term><option>--instance</option></term>
<listitem><para>With <option>--unescape</option>, unescape
and print only the instance part of an instantiated unit name
template. Results in an error for an uninstantiated template
like <filename>ssh@.service</filename> or a non-template name
like <filename>ssh.service</filename>.
Must be used in conjunction with <option>--unescape</option>
and may not be used in conjunction with
<option>--template</option>.</para></listitem>
</varlistentry>
<xi:include href="standard-options.xml" xpointer="help" /> <xi:include href="standard-options.xml" xpointer="help" />
<xi:include href="standard-options.xml" xpointer="version" /> <xi:include href="standard-options.xml" xpointer="version" />
</variablelist> </variablelist>
@ -144,6 +158,10 @@ tmp-waldi-foobar.mount</programlisting>
systemd-nspawn@My\x20Container\x201.service systemd-nspawn@containerb.service systemd-nspawn@container-III.service</programlisting> systemd-nspawn@My\x20Container\x201.service systemd-nspawn@containerb.service systemd-nspawn@container-III.service</programlisting>
<para>To extract the instance part of an instantiated unit:</para> <para>To extract the instance part of an instantiated unit:</para>
<programlisting>$ systemd-escape -u --instance 'systemd-nspawn@My\x20Container\x201.service'
My Container 1</programlisting>
<para>To extract the instance part of an instance of a particular template:</para>
<programlisting>$ systemd-escape -u --template=systemd-nspawn@.service 'systemd-nspawn@My\x20Container\x201.service' <programlisting>$ systemd-escape -u --template=systemd-nspawn@.service 'systemd-nspawn@My\x20Container\x201.service'
My Container 1</programlisting> My Container 1</programlisting>
</refsect1> </refsect1>

View File

@ -21,6 +21,7 @@ static enum {
static const char *arg_suffix = NULL; static const char *arg_suffix = NULL;
static const char *arg_template = NULL; static const char *arg_template = NULL;
static bool arg_path = false; static bool arg_path = false;
static bool arg_instance = false;
static void help(void) { static void help(void) {
printf("%s [OPTIONS...] [NAME...]\n\n" printf("%s [OPTIONS...] [NAME...]\n\n"
@ -29,6 +30,7 @@ static void help(void) {
" --version Show package version\n" " --version Show package version\n"
" --suffix=SUFFIX Unit suffix to append to escaped strings\n" " --suffix=SUFFIX Unit suffix to append to escaped strings\n"
" --template=TEMPLATE Insert strings as instance into template\n" " --template=TEMPLATE Insert strings as instance into template\n"
" --instance With --unescape, show just the instance part\n"
" -u --unescape Unescape strings\n" " -u --unescape Unescape strings\n"
" -m --mangle Mangle strings\n" " -m --mangle Mangle strings\n"
" -p --path When escaping/unescaping assume the string is a path\n" " -p --path When escaping/unescaping assume the string is a path\n"
@ -51,6 +53,7 @@ static int parse_argv(int argc, char *argv[]) {
{ "unescape", no_argument, NULL, 'u' }, { "unescape", no_argument, NULL, 'u' },
{ "mangle", no_argument, NULL, 'm' }, { "mangle", no_argument, NULL, 'm' },
{ "path", no_argument, NULL, 'p' }, { "path", no_argument, NULL, 'p' },
{ "instance", no_argument, NULL, 'i' },
{} {}
}; };
@ -102,6 +105,10 @@ static int parse_argv(int argc, char *argv[]) {
arg_path = true; arg_path = true;
break; break;
case 'i':
arg_instance = true;
break;
case '?': case '?':
return -EINVAL; return -EINVAL;
@ -134,6 +141,16 @@ static int parse_argv(int argc, char *argv[]) {
return -EINVAL; return -EINVAL;
} }
if (arg_instance && arg_action != ACTION_UNESCAPE) {
log_error("--instance must be used in conjunction with --unescape.");
return -EINVAL;
}
if (arg_instance && arg_template) {
log_error("--instance may not be combined with --template.");
return -EINVAL;
}
return 1; return 1;
} }
@ -197,7 +214,7 @@ int main(int argc, char *argv[]) {
case ACTION_UNESCAPE: { case ACTION_UNESCAPE: {
_cleanup_free_ char *name = NULL; _cleanup_free_ char *name = NULL;
if (arg_template) { if (arg_template || arg_instance) {
_cleanup_free_ char *template = NULL; _cleanup_free_ char *template = NULL;
r = unit_name_to_instance(*i, &name); r = unit_name_to_instance(*i, &name);
@ -215,7 +232,7 @@ int main(int argc, char *argv[]) {
log_error_errno(r, "Failed to extract template: %m"); log_error_errno(r, "Failed to extract template: %m");
goto finish; goto finish;
} }
if (!streq(arg_template, template)) { if (arg_template && !streq(arg_template, template)) {
log_error("Unit %s template %s does not match specified template %s.", *i, template, arg_template); log_error("Unit %s template %s does not match specified template %s.", *i, template, arg_template);
r = -EINVAL; r = -EINVAL;
goto finish; goto finish;