]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
journal: do not trigger assertion when journal_file_close() get NULL
authorYu Watanabe <watanabe.yu+github@gmail.com>
Tue, 28 May 2019 03:40:17 +0000 (12:40 +0900)
committerYu Watanabe <watanabe.yu+github@gmail.com>
Tue, 28 May 2019 09:07:18 +0000 (18:07 +0900)
We generally expect destructors to not complain if a NULL argument is passed.

Closes #12400.

src/journal/journal-file.c
src/journal/journald-server.c

index c38c3e7c14f3f04a825d46741bdbb56d6bded63e..c2dcf76deb86dd177594b1bbe9cccb3bc41e9fb2 100644 (file)
@@ -340,7 +340,8 @@ bool journal_file_is_offlining(JournalFile *f) {
 }
 
 JournalFile* journal_file_close(JournalFile *f) {
-        assert(f);
+        if (!f)
+                return NULL;
 
 #if HAVE_GCRYPT
         /* Write the final tag */
index 414571191f8729427bec9eb558781be64899a520..b2638c09b355dfcc5623359ed61bdee842d5bfe9 100644 (file)
@@ -2232,11 +2232,8 @@ void server_done(Server *s) {
 
         client_context_flush_all(s);
 
-        if (s->system_journal)
-                (void) journal_file_close(s->system_journal);
-
-        if (s->runtime_journal)
-                (void) journal_file_close(s->runtime_journal);
+        (void) journal_file_close(s->system_journal);
+        (void) journal_file_close(s->runtime_journal);
 
         ordered_hashmap_free_with_destructor(s->user_journals, journal_file_close);