We changed enough of dhcpcd-qt in 2017 to warrant a copyright bump.
[dhcpcd-ui] / src / dhcpcd-qt / dhcpcd-singleton.cpp
index 6ca87f78e6c1f110340bf45c19174884ffbba646..9dc5435ddcfeffcb4428168e7c5be08361b24202 100644 (file)
@@ -1,6 +1,6 @@
 /*
  * dhcpcd-qt
- * Copyright 2014-2015 Roy Marples <roy@marples.name>
+ * Copyright 2014-2017 Roy Marples <roy@marples.name>
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  * SUCH DAMAGE.
  */
 
+#include <sys/stat.h>
 #include <sys/file.h>
+#include <errno.h>
 #include <fcntl.h>
+#include <stdio.h>
 #include <string.h>
 #include <unistd.h>
 
-#include <cerrno>
-#include <iostream>
 #include <string>
 
+#include "dhcpcd.h"
 #include "dhcpcd-singleton.h"
 
 using namespace std;
@@ -53,8 +55,18 @@ bool DhcpcdSingleton::lock()
        string file;
        const char *display;
 
-       file = "/tmp/.dhcpcd-qt-";
+       file = DHCPCD_TMP_DIR;
+       file += "-";
        file += getlogin();
+       if (mkdir(file.c_str(), DHCPCD_TMP_DIR_PERM) == -1 &&
+           errno != EEXIST)
+       {
+               fprintf(stderr, "dhcpcd-qt: mkdir: %s: %s\n",
+                   file.c_str(), strerror(errno));
+               return false;
+       }
+
+       file += "/dhcpcd-qt";
        display = getenv("DISPLAY");
        if (display && *display != '\0' && strchr(display, '/') == NULL) {
                file += '.';
@@ -63,14 +75,16 @@ bool DhcpcdSingleton::lock()
        file += ".lock";
        fd = open(file.c_str(), O_WRONLY | O_CREAT | O_NONBLOCK, 0664);
        if (fd == -1) {
-               cerr << "dhcpcd-qt: " << "open: " << file << ": "
-                   << strerror(errno) << endl;
+               fprintf(stderr, "dhcpcd-qt: open: %s: %s\n",
+                   file.c_str(), strerror(errno));
                return false;
        }
        if (flock(fd, LOCK_EX | LOCK_NB) == -1) {
-               if (errno != EAGAIN)
-                       cerr << "dhcpcd-qt: " << "flock: " << file << ": "
-                           << strerror(errno) << endl;
+               if (errno == EAGAIN)
+                       fprintf(stderr, "dhcpcd-qt: already running\n");
+               else
+                       fprintf(stderr, "dhcpcd-qt: flock: %s: %s\n",
+                           file.c_str(), strerror(errno));
                return false;
        }
        return true;