From d848b9cbfa0ba72381363accce481600169df2eb Mon Sep 17 00:00:00 2001 From: =?utf8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= Date: Sun, 27 Jan 2013 19:44:52 -0500 Subject: [PATCH 1/1] Move generic specifier functions to shared No functional change. This makes it possible to use them in install.c. --- src/core/unit-printf.c | 36 ------------------------------------ src/shared/specifier.c | 36 ++++++++++++++++++++++++++++++++++++ src/shared/specifier.h | 6 +++++- 3 files changed, 41 insertions(+), 37 deletions(-) diff --git a/src/core/unit-printf.c b/src/core/unit-printf.c index a58c96c23..3aa735e5b 100644 --- a/src/core/unit-printf.c +++ b/src/core/unit-printf.c @@ -211,42 +211,6 @@ static char *specifier_user_shell(char specifier, void *data, void *userdata) { return strdup(shell); } -static char *specifier_machine_id(char specifier, void *data, void *userdata) { - sd_id128_t id; - char *buf; - int r; - - r = sd_id128_get_machine(&id); - if (r < 0) - return NULL; - - buf = new(char, 33); - if (!buf) - return NULL; - - return sd_id128_to_string(id, buf); -} - -static char *specifier_boot_id(char specifier, void *data, void *userdata) { - sd_id128_t id; - char *buf; - int r; - - r = sd_id128_get_boot(&id); - if (r < 0) - return NULL; - - buf = new(char, 33); - if (!buf) - return NULL; - - return sd_id128_to_string(id, buf); -} - -static char *specifier_host_name(char specifier, void *data, void *userdata) { - return gethostname_malloc(); -} - char *unit_name_printf(Unit *u, const char* format) { /* diff --git a/src/shared/specifier.c b/src/shared/specifier.c index 599027cd4..7577c9105 100644 --- a/src/shared/specifier.c +++ b/src/shared/specifier.c @@ -109,3 +109,39 @@ char *specifier_printf(const char *text, const Specifier table[], void *userdata char* specifier_string(char specifier, void *data, void *userdata) { return strdup(strempty(data)); } + +char *specifier_machine_id(char specifier, void *data, void *userdata) { + sd_id128_t id; + char *buf; + int r; + + r = sd_id128_get_machine(&id); + if (r < 0) + return NULL; + + buf = new(char, 33); + if (!buf) + return NULL; + + return sd_id128_to_string(id, buf); +} + +char *specifier_boot_id(char specifier, void *data, void *userdata) { + sd_id128_t id; + char *buf; + int r; + + r = sd_id128_get_boot(&id); + if (r < 0) + return NULL; + + buf = new(char, 33); + if (!buf) + return NULL; + + return sd_id128_to_string(id, buf); +} + +char *specifier_host_name(char specifier, void *data, void *userdata) { + return gethostname_malloc(); +} diff --git a/src/shared/specifier.h b/src/shared/specifier.h index 25a27a423..0440dcac4 100644 --- a/src/shared/specifier.h +++ b/src/shared/specifier.h @@ -31,4 +31,8 @@ typedef struct Specifier { char *specifier_printf(const char *text, const Specifier table[], void *userdata); -char* specifier_string(char specifier, void *data, void *userdata); +char *specifier_string(char specifier, void *data, void *userdata); + +char *specifier_machine_id(char specifier, void *data, void *userdata); +char *specifier_boot_id(char specifier, void *data, void *userdata); +char *specifier_host_name(char specifier, void *data, void *userdata); -- 2.30.2