autogenerating DEFAULT_CONFIG via CMAKE
authorFelix Morgner <felix.morgner@gmail.com>
Wed, 15 Jan 2014 15:26:20 +0000 (16:26 +0100)
committerFelix Morgner <felix.morgner@gmail.com>
Wed, 15 Jan 2014 15:26:20 +0000 (16:26 +0100)
The DEFAULT_CONFIG preprocessor #define is now generated
based on the CMAKE_INSTALL_PREFIX of cmake. This will make
sure, that the config file is located under the same
hirarchy as the executable.

src/conf.h
src/config.h.in
src/server.c

index 6a4ee6938d5cf7a293b8ae751bed680b6298e58d..8253fb330ba3c190f0d6331e2b07671c83bdd81f 100644 (file)
@@ -32,8 +32,7 @@
 #define CONF_H_24564356
 
 #include "messages.h"
-
-#define DEFAULT_CONFIG "/etc/umurmur.conf"
+#include "config.h"
 
 typedef enum param {
        CERTIFICATE,
index aaedfcab36b9e3c45c134c366151ed0785990ca8..a8a17989eddc6d2788a73ba33498cec24c182cfe 100644 (file)
@@ -2,5 +2,6 @@
 #define CONFIG_H
 
 #cmakedefine USE_POLARSSL
+#define DEFAULT_CONFIG "${CMAKE_INSTALL_PREFIX}/etc/umurmurd.conf"
 
 #endif // CONFIG_H
index 7c7675b6c6fbd5df0cc61f5516146d3d7890bba9..05f5213abc058575cd22b1591ecb68553188cf3d 100644 (file)
@@ -52,7 +52,7 @@
 #define UDP_SOCK 1
 
 /* globals */
-int udpsock; 
+int udpsock;
 bool_t shutdown_server;
 extern char *bindaddr;
 extern int bindport;
@@ -67,7 +67,7 @@ void Server_run()
        etimer_t janitorTimer;
        unsigned short port;
        in_addr_t inet_address;
-       
+
        /* max clients + listen sock + udp sock + client connecting that will be disconnected */
        pollfds = malloc((getIntConf(MAX_CLIENTS) + 3) * sizeof(struct pollfd));
        if (pollfds == NULL)
@@ -78,7 +78,7 @@ void Server_run()
                port = htons(bindport);
        else
                port = htons(getIntConf(BINDPORT));
-       
+
        if (bindaddr != NULL && inet_addr(bindaddr) != -1)
                inet_address = inet_addr(bindaddr);
        else if (inet_addr(getStrConf(BINDADDR)) !=  -1)
@@ -86,7 +86,7 @@ void Server_run()
        else
                inet_address = inet_addr("0.0.0.0");
        Log_info("Bind to %s:%hu", inet_address == 0 ? "*" : inet_ntoa(*((struct in_addr *)&inet_address)), ntohs(port));
-       
+
        /* Prepare TCP socket */
        memset(&sin, 0, sizeof(sin));
        tcpsock = socket(PF_INET, SOCK_STREAM, 0);
@@ -95,15 +95,15 @@ void Server_run()
        if (setsockopt(tcpsock, SOL_SOCKET, SO_REUSEADDR, &sockopt, sizeof(int)) != 0)
                Log_fatal("setsockopt: %s", strerror(errno));
        sin.sin_family = AF_INET;
-       sin.sin_port = port;    
+       sin.sin_port = port;
        sin.sin_addr.s_addr = inet_address;
-       
+
        rc = bind(tcpsock, (struct sockaddr *) &sin, sizeof (struct sockaddr_in));
        if (rc < 0) Log_fatal("bind: %s", strerror(errno));
        rc = listen(tcpsock, 3);
        if (rc < 0) Log_fatal("listen");
        fcntl(tcpsock, F_SETFL, O_NONBLOCK);
-       
+
        pollfds[LISTEN_SOCK].fd = tcpsock;
        pollfds[LISTEN_SOCK].events = POLLIN;
 
@@ -113,7 +113,7 @@ void Server_run()
        sin.sin_family = AF_INET;
        sin.sin_port = port;
        sin.sin_addr.s_addr = inet_address;
-       
+
        rc = bind(udpsock, (struct sockaddr *) &sin, sizeof (struct sockaddr_in));
        if (rc < 0)
                Log_fatal("bind %d %s: %s", getIntConf(BINDPORT), getStrConf(BINDADDR), strerror(errno));
@@ -125,26 +125,26 @@ void Server_run()
        rc = setsockopt(udpsock, IPPROTO_IP, IP_TOS, &val, sizeof(val));
        if (rc < 0)
                Log_warn("Server: Failed to set TOS for UDP Socket");
-       
+
        fcntl(udpsock, F_SETFL, O_NONBLOCK);
        pollfds[UDP_SOCK].fd = udpsock;
        pollfds[UDP_SOCK].events = POLLIN | POLLHUP | POLLERR;
-       
+
        Timer_init(&janitorTimer);
-       
+
        Log_info("uMurmur version %s ('%s') protocol version %d.%d.%d",
                 UMURMUR_VERSION, UMURMUR_CODENAME, PROTVER_MAJOR, PROTVER_MINOR, PROTVER_PATCH);
        Log_info("Visit http://code.google.com/p/umurmur/");
-       
+
        /* Main server loop */
        while (!shutdown_server) {
                struct sockaddr_in remote;
                int i;
-               
+
                pollfds[UDP_SOCK].revents = 0;
                pollfds[TCP_SOCK].revents = 0;
                clientcount = Client_getfds(&pollfds[2]);
-               
+
                timeout = (int)(1000000LL - (int64_t)Timer_elapsed(&janitorTimer)) / 1000LL;
                if (timeout <= 0) {
                        Client_janitor();
@@ -188,7 +188,7 @@ void Server_run()
                                Client_write_fd(pollfds[i + 2].fd);
                        }
                }
-       }       
+       }
 
        /* Disconnect clients */
        Client_disconnect_all();