X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=lib%2Fpidfile.c;h=426cbf392c10d903add23a1ae130fd9e4b96bfb7;hb=7e4d57adf54ce369e4111bde0ccd3ea4b9e853ee;hp=61a802f69713c78e78dedfb4bf81680eac884402;hpb=42e01abd54bd36ee84a45a2b646cfa27034de8d1;p=tinc diff --git a/lib/pidfile.c b/lib/pidfile.c index 61a802f6..426cbf39 100644 --- a/lib/pidfile.c +++ b/lib/pidfile.c @@ -37,7 +37,7 @@ pid_t read_pid (char *pidfile) { FILE *f; - long pid; + long pid = 0; if (!(f=fopen(pidfile,"r"))) return 0; @@ -84,8 +84,12 @@ pid_t write_pid (char *pidfile) int fd; pid_t pid; - if ( ((fd = open(pidfile, O_RDWR|O_CREAT, 0644)) == -1) - || ((f = fdopen(fd, "r+")) == NULL) ) { + if ((fd = open(pidfile, O_RDWR|O_CREAT, 0644)) == -1) { + return 0; + } + + if ((f = fdopen(fd, "r+")) == NULL) { + close(fd); return 0; } @@ -98,18 +102,18 @@ pid_t write_pid (char *pidfile) pid = getpid(); if (!fprintf(f,"%ld\n", (long)pid)) { - close(fd); + fclose(f); return 0; } fflush(f); #ifdef HAVE_FLOCK if (flock(fd, LOCK_UN) == -1) { - close(fd); + fclose(f); return 0; } #endif - close(fd); + fclose(f); return pid; }