From: Zbigniew Jędrzejewski-Szmek Date: Sat, 8 Nov 2014 15:06:12 +0000 (-0500) Subject: manager: let manager_free() handle NULLs X-Git-Tag: v218~386 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=06d8d842e9de8656d9a46926e7ae7ff967b69ef8;p=thirdparty%2Fsystemd.git manager: let manager_free() handle NULLs This makes the calling code a bit simpler. --- diff --git a/src/core/main.c b/src/core/main.c index 64acdf76e1d..b44e7f9cddb 100644 --- a/src/core/main.c +++ b/src/core/main.c @@ -1799,10 +1799,7 @@ int main(int argc, char *argv[]) { finish: pager_close(); - if (m) { - manager_free(m); - m = NULL; - } + m = manager_free(m); for (j = 0; j < ELEMENTSOF(arg_default_rlimit); j++) { free(arg_default_rlimit[j]); diff --git a/src/core/manager.c b/src/core/manager.c index 7abc8a9a5e4..4c3264b3734 100644 --- a/src/core/manager.c +++ b/src/core/manager.c @@ -889,11 +889,12 @@ static void manager_clear_jobs_and_units(Manager *m) { m->n_running_jobs = 0; } -void manager_free(Manager *m) { +Manager* manager_free(Manager *m) { UnitType c; int i; - assert(m); + if (!m) + return NULL; manager_clear_jobs_and_units(m); @@ -955,6 +956,7 @@ void manager_free(Manager *m) { hashmap_free(m->units_requiring_mounts_for); free(m); + return NULL; } int manager_enumerate(Manager *m) { diff --git a/src/core/manager.h b/src/core/manager.h index ab7254849c3..02535023a32 100644 --- a/src/core/manager.h +++ b/src/core/manager.h @@ -296,7 +296,7 @@ struct Manager { }; int manager_new(SystemdRunningAs running_as, bool test_run, Manager **m); -void manager_free(Manager *m); +Manager* manager_free(Manager *m); int manager_enumerate(Manager *m); int manager_startup(Manager *m, FILE *serialization, FDSet *fds);