diff options
Diffstat (limited to 'src/shared')
| l--------- | src/shared/Makefile | 1 | ||||
| -rw-r--r-- | src/shared/conf-parser.c | 1 | ||||
| -rw-r--r-- | src/shared/conf-parser.h | 1 | ||||
| -rw-r--r-- | src/shared/pager.c | 12 | 
4 files changed, 14 insertions, 1 deletions
| diff --git a/src/shared/Makefile b/src/shared/Makefile new file mode 120000 index 0000000000..d0b0e8e008 --- /dev/null +++ b/src/shared/Makefile @@ -0,0 +1 @@ +../Makefile
\ No newline at end of file diff --git a/src/shared/conf-parser.c b/src/shared/conf-parser.c index d99aa1d6e9..1f4aea6d6b 100644 --- a/src/shared/conf-parser.c +++ b/src/shared/conf-parser.c @@ -450,6 +450,7 @@ int config_parse_many(const char *conf_file,  DEFINE_PARSER(int, int, safe_atoi)  DEFINE_PARSER(long, long, safe_atoli) +DEFINE_PARSER(uint32, uint32_t, safe_atou32)  DEFINE_PARSER(uint64, uint64_t, safe_atou64)  DEFINE_PARSER(unsigned, unsigned, safe_atou)  DEFINE_PARSER(double, double, safe_atod) diff --git a/src/shared/conf-parser.h b/src/shared/conf-parser.h index 6152ee33b9..66c80890d3 100644 --- a/src/shared/conf-parser.h +++ b/src/shared/conf-parser.h @@ -104,6 +104,7 @@ int config_parse_many(const char *conf_file,      /* possibly NULL */  int config_parse_int(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_unsigned(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_long(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); +int config_parse_uint32(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_uint64(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_double(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line,  const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata);  int config_parse_iec_size(const char *unit, const char *filename, unsigned line, const char *section, unsigned section_line, const char *lvalue, int ltype, const char *rvalue, void *data, void *userdata); diff --git a/src/shared/pager.c b/src/shared/pager.c index 85f8fa5b39..3992f9c837 100644 --- a/src/shared/pager.c +++ b/src/shared/pager.c @@ -82,7 +82,7 @@ int pager_open(bool jump_to_end) {          /* In the child start the pager */          if (pager_pid == 0) { -                const char* less_opts; +                const char* less_opts, *less_charset;                  (void) reset_all_signal_handlers();                  (void) reset_signal_mask(); @@ -90,6 +90,7 @@ int pager_open(bool jump_to_end) {                  dup2(fd[0], STDIN_FILENO);                  safe_close_pair(fd); +                /* Initialize a good set of less options */                  less_opts = getenv("SYSTEMD_LESS");                  if (!less_opts)                          less_opts = "FRSXMK"; @@ -97,6 +98,15 @@ int pager_open(bool jump_to_end) {                          less_opts = strjoina(less_opts, " +G");                  setenv("LESS", less_opts, 1); +                /* Initialize a good charset for less. This is +                 * particularly important if we output UTF-8 +                 * characters. */ +                less_charset = getenv("SYSTEMD_LESSCHARSET"); +                if (!less_charset && is_locale_utf8()) +                        less_charset = "utf-8"; +                if (less_charset) +                        setenv("LESSCHARSET", less_charset, 1); +                  /* Make sure the pager goes away when the parent dies */                  if (prctl(PR_SET_PDEATHSIG, SIGTERM) < 0)                          _exit(EXIT_FAILURE); | 
