From b750101eb236130cf056c675997decbac904cc49 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 17:35:18 +0200 Subject: Adding upstream version 252.22. Signed-off-by: Daniel Baumann --- src/shared/locale-setup.h | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 src/shared/locale-setup.h (limited to 'src/shared/locale-setup.h') diff --git a/src/shared/locale-setup.h b/src/shared/locale-setup.h new file mode 100644 index 0000000..ec3fc8c --- /dev/null +++ b/src/shared/locale-setup.h @@ -0,0 +1,28 @@ +/* SPDX-License-Identifier: LGPL-2.1-or-later */ +#pragma once + +#include "locale-util.h" +#include "time-util.h" + +typedef struct LocaleContext { + usec_t mtime; + char *locale[_VARIABLE_LC_MAX]; +} LocaleContext; + +typedef enum LocaleLoadFlag { + LOCALE_LOAD_PROC_CMDLINE = 1 << 0, + LOCALE_LOAD_LOCALE_CONF = 1 << 1, + LOCALE_LOAD_ENVIRONMENT = 1 << 2, + LOCALE_LOAD_SIMPLIFY = 1 << 3, +} LocaleLoadFlag; + +void locale_context_clear(LocaleContext *c); +int locale_context_load(LocaleContext *c, LocaleLoadFlag flag); +int locale_context_build_env(const LocaleContext *c, char ***ret_set, char ***ret_unset); +int locale_context_save(LocaleContext *c, char ***ret_set, char ***ret_unset); + +int locale_context_merge(const LocaleContext *c, char *l[_VARIABLE_LC_MAX]); +void locale_context_take(LocaleContext *c, char *l[_VARIABLE_LC_MAX]); +bool locale_context_equal(const LocaleContext *c, char *l[_VARIABLE_LC_MAX]); + +int locale_setup(char ***environment); -- cgit v1.2.3