return ustcomm_connect_path(path, conn, pid);
}
+static int ensure_dir_exists(const char *dir)
+{
+ struct stat st;
+ int result;
+
+ if(!strcmp(dir, ""))
+ return -1;
+
+ result = stat(dir, &st);
+ if(result == -1 && errno != ENOENT) {
+ return -1;
+ }
+ else if(result == -1) {
+ /* ENOENT */
+ char buf[200];
+ int result;
+
+ result = snprintf(buf, sizeof(buf), "mkdir -p \"%s\"", dir);
+ if(result >= sizeof(buf)) {
+ ERR("snprintf buffer overflow");
+ return -1;
+ }
+ result = system(buf);
+ if(result != 0) {
+ ERR("executing command %s", buf);
+ return -1;
+ }
+ }
+
+ return 0;
+}
+
/* Called by an application to initialize its server so daemons can
* connect to it.
*/
return -1;
}
+ result = ensure_dir_exists(SOCK_DIR);
+ if(result == -1) {
+ ERR("Unable to create socket directory %s", SOCK_DIR);
+ return -1;
+ }
+
handle->server.listen_fd = init_named_socket(name, &(handle->server.socketpath));
if(handle->server.listen_fd < 0) {
ERR("Error initializing named socket (%s). Check that directory exists and that it is writable.", name);
asprintf(&name, "%s", sock_path);
}
else {
+ int result;
+
+ /* Only check if socket dir exists if we are using the default directory */
+ result = ensure_dir_exists(SOCK_DIR);
+ if(result == -1) {
+ ERR("Unable to create socket directory %s", SOCK_DIR);
+ return -1;
+ }
+
asprintf(&name, "%s/%s", SOCK_DIR, "ustd");
}