diff options
Diffstat (limited to 'src/basic')
| -rw-r--r-- | src/basic/copy.c | 2 | ||||
| -rw-r--r-- | src/basic/fs-util.h | 6 | ||||
| -rw-r--r-- | src/basic/log.c | 7 | ||||
| -rw-r--r-- | src/basic/log.h | 1 | ||||
| -rw-r--r-- | src/basic/strv.c | 12 | 
5 files changed, 20 insertions, 8 deletions
| diff --git a/src/basic/copy.c b/src/basic/copy.c index 6273ac9b47..e120b9eb4e 100644 --- a/src/basic/copy.c +++ b/src/basic/copy.c @@ -558,7 +558,7 @@ int copy_file_atomic(const char *from, const char *to, mode_t mode, unsigned cha          } else                  r = rename_noreplace(AT_FDCWD, t, AT_FDCWD, to);          if (r < 0) { -                (void) unlink_noerrno(t); +                (void) unlink(t);                  return r;          } diff --git a/src/basic/fs-util.h b/src/basic/fs-util.h index 5fe5c71ff0..094acf1799 100644 --- a/src/basic/fs-util.h +++ b/src/basic/fs-util.h @@ -91,3 +91,9 @@ static inline void rmdir_and_free(char *p) {          free(p);  }  DEFINE_TRIVIAL_CLEANUP_FUNC(char*, rmdir_and_free); + +static inline void unlink_and_free(char *p) { +        (void) unlink(p); +        free(p); +} +DEFINE_TRIVIAL_CLEANUP_FUNC(char*, unlink_and_free); diff --git a/src/basic/log.c b/src/basic/log.c index e6d2d61d72..36efc9ac7d 100644 --- a/src/basic/log.c +++ b/src/basic/log.c @@ -72,6 +72,7 @@ static bool show_color = false;  static bool show_location = false;  static bool upgrade_syslog_to_journal = false; +static bool always_reopen_console = false;  /* Akin to glibc's __abort_msg; which is private and we hence cannot   * use here. */ @@ -95,7 +96,7 @@ static int log_open_console(void) {          if (console_fd >= 0)                  return 0; -        if (getpid() == 1) { +        if (always_reopen_console) {                  console_fd = open_terminal("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC);                  if (console_fd < 0)                          return console_fd; @@ -1171,3 +1172,7 @@ int log_syntax_internal(                          unit_fmt, unit,                          NULL);  } + +void log_set_always_reopen_console(bool b) { +        always_reopen_console = b; +} diff --git a/src/basic/log.h b/src/basic/log.h index 9cacbb6b70..72714e02e5 100644 --- a/src/basic/log.h +++ b/src/basic/log.h @@ -220,6 +220,7 @@ LogTarget log_target_from_string(const char *s) _pure_;  void log_received_signal(int level, const struct signalfd_siginfo *si);  void log_set_upgrade_syslog_to_journal(bool b); +void log_set_always_reopen_console(bool b);  int log_syntax_internal(                  const char *unit, diff --git a/src/basic/strv.c b/src/basic/strv.c index 60f92e6373..0eec868eed 100644 --- a/src/basic/strv.c +++ b/src/basic/strv.c @@ -564,6 +564,9 @@ int strv_extend_front(char ***l, const char *value) {          /* Like strv_extend(), but prepends rather than appends the new entry */ +        if (!value) +                return 0; +          n = strv_length(*l);          /* Increase and overflow check. */ @@ -571,12 +574,9 @@ int strv_extend_front(char ***l, const char *value) {          if (m < n)                  return -ENOMEM; -        if (value) { -                v = strdup(value); -                if (!v) -                        return -ENOMEM; -        } else -                v = NULL; +        v = strdup(value); +        if (!v) +                return -ENOMEM;          c = realloc_multiply(*l, sizeof(char*), m);          if (!c) { | 
