Try sending SIGTERM if we cannot connect to a tincd but we know its PID.

This commit is contained in:
Guus Sliepen 2012-08-01 15:14:48 +02:00
parent 7a71d48009
commit 07980b056c

View file

@ -714,8 +714,16 @@ static int cmd_start(int argc, char *argv[]) {
static int cmd_stop(int argc, char *argv[]) { static int cmd_stop(int argc, char *argv[]) {
#ifndef HAVE_MINGW #ifndef HAVE_MINGW
if(!connect_tincd()) if(!connect_tincd()) {
if(pid) {
if(kill(pid, SIGTERM))
return 1; 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); 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) { if(!recvline(fd, line, sizeof line) || sscanf(line, "%d %d %d", &code, &req, &result) != 3 || code != CONTROL || req != REQ_STOP || result) {