diff options
author | 2019-05-20 15:42:29 +0300 | |
---|---|---|
committer | 2019-05-20 15:42:29 +0300 | |
commit | 0232ddd00be27f42da43ce9d7312f05580c2ebc6 (patch) | |
tree | c8c6e3ad8d75e0056569ef469ecf8601a2e67eca /src/daemon/main.c | |
parent | 18953ca0b4742306b36c9abf243ef0599985b45e (diff) | |
download | usurpation-0232ddd00be27f42da43ce9d7312f05580c2ebc6.tar.gz usurpation-0232ddd00be27f42da43ce9d7312f05580c2ebc6.tar.bz2 usurpation-0232ddd00be27f42da43ce9d7312f05580c2ebc6.zip |
daemon: improve cleanup code.
Resolves all memory leaks that can be possibly resolved, glib
nonwithstanding.
Signed-off-by: Gediminas Jakutis <gediminas@varciai.lt>
Diffstat (limited to 'src/daemon/main.c')
-rw-r--r-- | src/daemon/main.c | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/src/daemon/main.c b/src/daemon/main.c index 41e798b..94e59fd 100644 --- a/src/daemon/main.c +++ b/src/daemon/main.c @@ -21,11 +21,18 @@ #include <unistd.h> #include <time.h> +#include <stdlib.h> #include <stdio.h> #include "settings.h" #include "net.h" #include "purple.h" +static struct _state { + int nd; +} _progstate; + +void cleanup(void); + /* the logic is a placeholder right now */ int main(int argc, char **argv) { @@ -34,8 +41,9 @@ int main(int argc, char **argv) printf("Usurpation daemon version %s starting\n", version); + atexit(cleanup); settings_init(); - net_init(setting_port()); /* TODO: get port from settings. */ + _progstate.nd = net_init(setting_port()); if (purple_init() && setting_verbose()) { fprintf(stderr, "libpurple initialization failed\n"); } @@ -52,4 +60,13 @@ int main(int argc, char **argv) /* noop */ } + + return 0; +} + +void cleanup(void) +{ + purple_close(); + net_close(_progstate.nd); + settings_cleanup(); } |