X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fshared%2Fsleep-config.c;h=e8998d6ff8721572f204c6295b388f4dd1713a24;hp=1064fd5cbd3f73800bcd106df6fd4b82ac47cdf0;hb=57095c3830fb5600442f3d3e92773096061bc263;hpb=1fa2f38f0f011010bf57522b42fcc168856a7003 diff --git a/src/shared/sleep-config.c b/src/shared/sleep-config.c index 1064fd5cb..e8998d6ff 100644 --- a/src/shared/sleep-config.c +++ b/src/shared/sleep-config.c @@ -1,5 +1,3 @@ -/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/ - /*** This file is part of systemd. @@ -19,19 +17,34 @@ along with systemd; If not, see . ***/ +#include +#include +#include #include +#include +#include +#include +#include "alloc-util.h" #include "conf-parser.h" -#include "sleep-config.h" +#include "def.h" +#include "fd-util.h" #include "fileio.h" #include "log.h" +#include "macro.h" +#include "parse-util.h" +#include "sleep-config.h" +#include "string-util.h" #include "strv.h" -#include "util.h" #define USE(x, y) do{ (x) = (y); (y) = NULL; } while(0) +#if 0 /// UNNEEDED by elogind int parse_sleep_config(const char *verb, char ***_modes, char ***_states) { - +#else +/// really only used in here. +static int parse_sleep_config(const char *verb, char ***_modes, char ***_states) { +#endif // 0 _cleanup_strv_free_ char **suspend_mode = NULL, **suspend_state = NULL, **hibernate_mode = NULL, **hibernate_state = NULL, @@ -48,10 +61,19 @@ int parse_sleep_config(const char *verb, char ***_modes, char ***_states) { {} }; +#if 0 /// elogind has its own config file config_parse_many(PKGSYSCONFDIR "/sleep.conf", - CONF_DIRS_NULSTR("systemd/sleep.conf"), + CONF_PATHS_NULSTR("systemd/sleep.conf.d"), "Sleep\0", config_item_table_lookup, items, false, NULL); +#else + const char* logind_conf = getenv("ELOGIND_CONF_FILE"); + if (!logind_conf) + logind_conf = PKGSYSCONFDIR "/logind.conf"; + config_parse(NULL, logind_conf, NULL, "Sleep\0", + config_item_table_lookup, items, false, + false, true, NULL); +#endif // 0 if (streq(verb, "suspend")) { /* empty by default */ @@ -226,7 +248,7 @@ static bool enough_memory_for_hibernation(void) { if (r < 0) return false; - r = get_status_field("/proc/meminfo", "\nActive(anon):", &active); + r = get_proc_field("/proc/meminfo", "Active(anon)", WHITESPACE, &active); if (r < 0) { log_error_errno(r, "Failed to retrieve Active(anon) from /proc/meminfo: %m"); return false;