+ xasprintf(&pidfilename, "%s" SLASH "pid", confbase);
+#else
+ bool fallback = false;
+ if(daemon) {
+ if(access(LOCALSTATEDIR, R_OK | W_OK | X_OK))
+ fallback = true;
+ } else {
+ char fname[PATH_MAX];
+ snprintf(fname, sizeof fname, LOCALSTATEDIR SLASH "run" SLASH "%s.pid", identname);
+ if(access(fname, R_OK)) {
+ snprintf(fname, sizeof fname, "%s" SLASH "pid", confbase);
+ if(!access(fname, R_OK))
+ fallback = true;
+ }
+ }
+
+ if(!fallback) {
+ if(!logfilename)
+ xasprintf(&logfilename, LOCALSTATEDIR SLASH "log" SLASH "%s.log", identname);
+
+ if(!pidfilename)
+ xasprintf(&pidfilename, LOCALSTATEDIR SLASH "run" SLASH "%s.pid", identname);
+ } else {
+ if(!logfilename)
+ xasprintf(&logfilename, "%s" SLASH "log", confbase);
+
+ if(!pidfilename) {
+ if(daemon)
+ logger(DEBUG_ALWAYS, LOG_WARNING, "Could not access " LOCALSTATEDIR SLASH " (%s), storing pid and socket files in %s" SLASH, strerror(errno), confbase);
+ xasprintf(&pidfilename, "%s" SLASH "pid", confbase);
+ }
+ }
+#endif