]> git.meshlink.io Git - meshlink/commitdiff
Try sending SIGTERM if we cannot connect to a tincd but we know its PID.
authorGuus Sliepen <guus@tinc-vpn.org>
Wed, 1 Aug 2012 13:14:48 +0000 (15:14 +0200)
committerGuus Sliepen <guus@tinc-vpn.org>
Wed, 1 Aug 2012 13:14:48 +0000 (15:14 +0200)
src/tincctl.c

index 619b90ece9328a0785907222d48df5a1cb0f6188..1cdcf586a2556511e8e1b27558b29f4080b1b02e 100644 (file)
@@ -714,8 +714,16 @@ static int cmd_start(int argc, char *argv[]) {
 
 static int cmd_stop(int argc, char *argv[]) {
 #ifndef HAVE_MINGW
-       if(!connect_tincd())
+       if(!connect_tincd()) {
+               if(pid) {
+                       if(kill(pid, SIGTERM)) 
+                               return 1;
+                       fprintf(stderr, "Sent TERM signal to process with PID %u.\n", pid);
+                       return 0;
+               }
+
                return 1;
+       }
 
        sendline(fd, "%d %d", CONTROL, REQ_STOP);
        if(!recvline(fd, line, sizeof line) || sscanf(line, "%d %d %d", &code, &req, &result) != 3 || code != CONTROL || req != REQ_STOP || result) {