|
|
@ -79,8 +79,8 @@ if ((result == -1) && (errno == ENOENT))
|
|
|
|
static char *locate_mcop_dir()
|
|
|
|
static char *locate_mcop_dir()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
struct passwd *pw_ent;
|
|
|
|
struct passwd *pw_ent;
|
|
|
|
char kde_tmp_dir[PATH_MAX+1];
|
|
|
|
string kde_tmp_dir;
|
|
|
|
char user_tmp_dir[PATH_MAX+1];
|
|
|
|
string user_tmp_dir;
|
|
|
|
int uid = getuid();
|
|
|
|
int uid = getuid();
|
|
|
|
const char *home_dir = getenv("HOME");
|
|
|
|
const char *home_dir = getenv("HOME");
|
|
|
|
const char *kde_home = uid ? getenv("KDEHOME") : getenv("KDEROOTHOME");
|
|
|
|
const char *kde_home = uid ? getenv("KDEHOME") : getenv("KDEROOTHOME");
|
|
|
@ -96,7 +96,7 @@ static char *locate_mcop_dir()
|
|
|
|
if (!tmp || !tmp[0])
|
|
|
|
if (!tmp || !tmp[0])
|
|
|
|
tmp = "/tmp";
|
|
|
|
tmp = "/tmp";
|
|
|
|
|
|
|
|
|
|
|
|
kde_tmp_dir[0] = 0;
|
|
|
|
kde_tmp_dir = "";
|
|
|
|
|
|
|
|
|
|
|
|
pw_ent = getpwuid(uid);
|
|
|
|
pw_ent = getpwuid(uid);
|
|
|
|
if (!pw_ent)
|
|
|
|
if (!pw_ent)
|
|
|
@ -105,12 +105,7 @@ static char *locate_mcop_dir()
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
strncpy(user_tmp_dir, tmp, PATH_MAX );
|
|
|
|
user_tmp_dir = string(tmp) + "/ksocket-" + string(pw_ent->pw_name);
|
|
|
|
user_tmp_dir[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
strncat(user_tmp_dir, "/ksocket-", PATH_MAX - strlen(user_tmp_dir) );
|
|
|
|
|
|
|
|
user_tmp_dir[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
strncat(user_tmp_dir, pw_ent->pw_name, PATH_MAX - strlen(user_tmp_dir));
|
|
|
|
|
|
|
|
user_tmp_dir[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!kde_home || !kde_home[0])
|
|
|
|
if (!kde_home || !kde_home[0])
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -127,44 +122,37 @@ static char *locate_mcop_dir()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
arts_fatal("Aborting. $HOME not set!");
|
|
|
|
arts_fatal("Aborting. $HOME not set!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (strlen(home_dir) > (PATH_MAX-100))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
arts_fatal("Aborting. Home directory path too long!");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
kde_home++;
|
|
|
|
kde_home++;
|
|
|
|
strncpy(kde_tmp_dir, home_dir, PATH_MAX);
|
|
|
|
kde_tmp_dir = string(home_dir);
|
|
|
|
kde_tmp_dir[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
strncat(kde_tmp_dir, kde_home, PATH_MAX - strlen(kde_tmp_dir));
|
|
|
|
kde_tmp_dir += kde_home;
|
|
|
|
|
|
|
|
|
|
|
|
/** Strip trailing '/' **/
|
|
|
|
/** Strip trailing '/' **/
|
|
|
|
if ( kde_tmp_dir[strlen(kde_tmp_dir)-1] == '/')
|
|
|
|
if ( kde_tmp_dir[kde_tmp_dir.length()-1] == '/')
|
|
|
|
kde_tmp_dir[strlen(kde_tmp_dir)-1] = 0;
|
|
|
|
kde_tmp_dir.resize(kde_tmp_dir.length()-1);
|
|
|
|
|
|
|
|
|
|
|
|
result = stat(kde_tmp_dir, &stat_buf);
|
|
|
|
result = stat(kde_tmp_dir.c_str(), &stat_buf);
|
|
|
|
if (result == -1)
|
|
|
|
if (result == -1)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
strncat(kde_tmp_dir, kde_prefix, PATH_MAX - strlen(kde_tmp_dir));
|
|
|
|
kde_tmp_dir += kde_prefix;
|
|
|
|
if (gethostname(kde_tmp_dir+strlen(kde_tmp_dir), PATH_MAX - strlen(kde_tmp_dir) - 1) != 0)
|
|
|
|
{
|
|
|
|
|
|
|
|
char buf[1024];
|
|
|
|
|
|
|
|
if (gethostname(buf, sizeof(buf)-1) != 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
arts_fatal("Aborting. Could not determine hostname or hostname too long.");
|
|
|
|
arts_fatal("Aborting. Could not determine hostname or hostname too long.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
kde_tmp_dir[sizeof(kde_tmp_dir)-1] = '\0';
|
|
|
|
buf[sizeof(buf)-1] = '\0';
|
|
|
|
|
|
|
|
kde_tmp_dir += buf;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
result = lstat(kde_tmp_dir, &stat_buf);
|
|
|
|
result = lstat(kde_tmp_dir.c_str(), &stat_buf);
|
|
|
|
if ((result == 0) && (S_ISDIR(stat_buf.st_mode)))
|
|
|
|
if ((result == 0) && (S_ISDIR(stat_buf.st_mode)))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
/* $KDEHOME/socket-$HOSTNAME is a normal directory. Do nothing. */
|
|
|
|
/* $KDEHOME/socket-$HOSTNAME is a normal directory. Do nothing. */
|
|
|
|
tmp_buf = (char *) malloc(PATH_MAX+1);
|
|
|
|
tmp_buf = strdup(kde_tmp_dir.c_str());
|
|
|
|
if (!tmp_buf)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
strncpy(tmp_buf, kde_tmp_dir, PATH_MAX);
|
|
|
|
|
|
|
|
tmp_buf[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return tmp_buf;
|
|
|
|
return tmp_buf;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -175,26 +163,32 @@ static char *locate_mcop_dir()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ((result == -1) || (!S_ISLNK(stat_buf.st_mode)))
|
|
|
|
if ((result == -1) || (!S_ISLNK(stat_buf.st_mode)))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
arts_warning("Error: \"%s\" is not a link or a directory.\n", kde_tmp_dir);
|
|
|
|
arts_warning("Error: \"%s\" is not a link or a directory.\n", kde_tmp_dir.c_str());
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
tmp_buf = (char *) malloc(PATH_MAX+1);
|
|
|
|
|
|
|
|
if (!tmp_buf)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* kde_tmp_dir is a link. Check whether it points to a valid directory. */
|
|
|
|
/* kde_tmp_dir is a link. Check whether it points to a valid directory. */
|
|
|
|
result = readlink(kde_tmp_dir, tmp_buf, PATH_MAX);
|
|
|
|
ssize_t size = 2048;
|
|
|
|
|
|
|
|
tmp_buf = NULL;
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
|
|
|
size *= 2;
|
|
|
|
|
|
|
|
tmp_buf = (char *) realloc(tmp_buf, size);
|
|
|
|
|
|
|
|
if (!tmp_buf)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
result = readlink(kde_tmp_dir.c_str(), tmp_buf, size - 1);
|
|
|
|
if (result == -1)
|
|
|
|
if (result == -1)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
arts_warning("Error: \"%s\" could not be read.\n", kde_tmp_dir);
|
|
|
|
arts_warning("Error: \"%s\" could not be read.\n", kde_tmp_dir.c_str());
|
|
|
|
free(tmp_buf);
|
|
|
|
free(tmp_buf);
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} while(result == size - 1);
|
|
|
|
tmp_buf[result] = '\0';
|
|
|
|
tmp_buf[result] = '\0';
|
|
|
|
|
|
|
|
|
|
|
|
// printf("Link points to \"%s\"\n", tmp_buf);
|
|
|
|
// printf("Link points to \"%s\"\n", tmp_buf);
|
|
|
|
if (strncmp(tmp_buf, user_tmp_dir, strlen(user_tmp_dir)) != 0)
|
|
|
|
if (strncmp(tmp_buf, user_tmp_dir.c_str(), user_tmp_dir.length()) != 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
arts_warning("Error: \"%s\" points to \"%s\" instead of \"%s\".\n", kde_tmp_dir, tmp_buf, user_tmp_dir);
|
|
|
|
arts_warning("Error: \"%s\" points to \"%s\" instead of \"%s\".\n", kde_tmp_dir.c_str(), tmp_buf, user_tmp_dir.c_str());
|
|
|
|
free(tmp_buf);
|
|
|
|
free(tmp_buf);
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -229,19 +223,19 @@ int create_link(const char *file, const char *tmp_dir)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static
|
|
|
|
static
|
|
|
|
int build_link(const char *tmp_prefix, const char *kde_prefix)
|
|
|
|
int build_link(string tmp_prefix, const char *kde_prefix)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
struct passwd *pw_ent;
|
|
|
|
struct passwd *pw_ent;
|
|
|
|
char kde_tmp_dir[PATH_MAX+1];
|
|
|
|
string kde_tmp_dir;
|
|
|
|
char user_tmp_dir[PATH_MAX+1];
|
|
|
|
string user_tmp_dir;
|
|
|
|
char tmp_buf[PATH_MAX+1];
|
|
|
|
char *tmp_buf;
|
|
|
|
int uid = getuid();
|
|
|
|
int uid = getuid();
|
|
|
|
const char *home_dir = getenv("HOME");
|
|
|
|
const char *home_dir = getenv("HOME");
|
|
|
|
const char *kde_home = uid ? getenv("KDEHOME") : getenv("KDEROOTHOME");
|
|
|
|
const char *kde_home = uid ? getenv("KDEHOME") : getenv("KDEROOTHOME");
|
|
|
|
int result;
|
|
|
|
int result;
|
|
|
|
struct stat stat_buf;
|
|
|
|
struct stat stat_buf;
|
|
|
|
|
|
|
|
|
|
|
|
kde_tmp_dir[0] = 0;
|
|
|
|
kde_tmp_dir = "";
|
|
|
|
|
|
|
|
|
|
|
|
pw_ent = getpwuid(uid);
|
|
|
|
pw_ent = getpwuid(uid);
|
|
|
|
if (!pw_ent)
|
|
|
|
if (!pw_ent)
|
|
|
@ -250,9 +244,7 @@ int build_link(const char *tmp_prefix, const char *kde_prefix)
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
strncpy(user_tmp_dir, tmp_prefix, PATH_MAX);
|
|
|
|
user_tmp_dir = tmp_prefix + string(pw_ent->pw_name);
|
|
|
|
user_tmp_dir[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
strncat(user_tmp_dir, pw_ent->pw_name, PATH_MAX - strlen(tmp_prefix));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!kde_home || !kde_home[0])
|
|
|
|
if (!kde_home || !kde_home[0])
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -270,89 +262,106 @@ int build_link(const char *tmp_prefix, const char *kde_prefix)
|
|
|
|
fprintf(stderr, "Aborting. $HOME not set!");
|
|
|
|
fprintf(stderr, "Aborting. $HOME not set!");
|
|
|
|
exit(255);
|
|
|
|
exit(255);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (strlen(home_dir) > (PATH_MAX-100))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
fprintf(stderr, "Aborting. Home directory path too long!");
|
|
|
|
|
|
|
|
exit(255);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
kde_home++;
|
|
|
|
kde_home++;
|
|
|
|
strncpy(kde_tmp_dir, home_dir, PATH_MAX);
|
|
|
|
kde_tmp_dir = string(home_dir);
|
|
|
|
kde_tmp_dir[ PATH_MAX ] = '\0';
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
strncat(kde_tmp_dir, kde_home, PATH_MAX - strlen(kde_tmp_dir));
|
|
|
|
kde_tmp_dir += kde_home;
|
|
|
|
|
|
|
|
|
|
|
|
/** Strip trailing '/' **/
|
|
|
|
/** Strip trailing '/' **/
|
|
|
|
if ( kde_tmp_dir[strlen(kde_tmp_dir)-1] == '/')
|
|
|
|
if ( kde_tmp_dir[kde_tmp_dir.length()-1] == '/')
|
|
|
|
kde_tmp_dir[strlen(kde_tmp_dir)-1] = 0;
|
|
|
|
kde_tmp_dir.resize(kde_tmp_dir.length()-1);
|
|
|
|
|
|
|
|
|
|
|
|
result = stat(kde_tmp_dir, &stat_buf);
|
|
|
|
result = stat(kde_tmp_dir.c_str(), &stat_buf);
|
|
|
|
if ((result == -1) && (errno == ENOENT))
|
|
|
|
if ((result == -1) && (errno == ENOENT))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
result = mkdir(kde_tmp_dir, 0700);
|
|
|
|
result = mkdir(kde_tmp_dir.c_str(), 0700);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (result == -1)
|
|
|
|
if (result == -1)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
strncat(kde_tmp_dir, kde_prefix, PATH_MAX - strlen(kde_tmp_dir));
|
|
|
|
kde_tmp_dir += kde_prefix;
|
|
|
|
if (gethostname(kde_tmp_dir+strlen(kde_tmp_dir), PATH_MAX - strlen(kde_tmp_dir) - 1) != 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
perror("Aborting. Could not determine hostname: ");
|
|
|
|
char buf[1024];
|
|
|
|
exit(255);
|
|
|
|
if (gethostname(buf, sizeof(buf)-1) != 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
arts_fatal("Aborting. Could not determine hostname or hostname too long.");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
buf[sizeof(buf)-1] = '\0';
|
|
|
|
|
|
|
|
kde_tmp_dir += buf;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
kde_tmp_dir[sizeof(kde_tmp_dir)-1] = '\0';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
result = lstat(kde_tmp_dir, &stat_buf);
|
|
|
|
result = lstat(kde_tmp_dir.c_str(), &stat_buf);
|
|
|
|
if ((result == 0) && (S_ISDIR(stat_buf.st_mode)))
|
|
|
|
if ((result == 0) && (S_ISDIR(stat_buf.st_mode)))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
/* $KDEHOME/tmp is a normal directory. Do nothing. */
|
|
|
|
/* $KDEHOME/tmp is a normal directory. Do nothing. */
|
|
|
|
printf("Directory \"%s\" already exists.\n", kde_tmp_dir);
|
|
|
|
printf("Directory \"%s\" already exists.\n", kde_tmp_dir.c_str());
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ((result == -1) && (errno == ENOENT))
|
|
|
|
if ((result == -1) && (errno == ENOENT))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
printf("Creating link %s.\n", kde_tmp_dir);
|
|
|
|
printf("Creating link %s.\n", kde_tmp_dir.c_str());
|
|
|
|
result = create_link(kde_tmp_dir, user_tmp_dir);
|
|
|
|
result = create_link(kde_tmp_dir.c_str(), user_tmp_dir.c_str());
|
|
|
|
if (result == 0) return 0; /* Success */
|
|
|
|
if (result == 0) return 0; /* Success */
|
|
|
|
unlink(kde_tmp_dir);
|
|
|
|
unlink(kde_tmp_dir.c_str());
|
|
|
|
strncat(user_tmp_dir, "XXXXXX", PATH_MAX - strlen(user_tmp_dir));
|
|
|
|
user_tmp_dir += "XXXXXX";
|
|
|
|
mktemp(user_tmp_dir); /* We want a directory, not a file, so using mkstemp makes no sense and is wrong */
|
|
|
|
tmp_buf = strdup(user_tmp_dir.c_str());
|
|
|
|
return create_link(kde_tmp_dir, user_tmp_dir);
|
|
|
|
mktemp(tmp_buf); /* We want a directory, not a file, so using mkstemp makes no sense and is wrong */
|
|
|
|
|
|
|
|
result = create_link(kde_tmp_dir.c_str(), tmp_buf);
|
|
|
|
|
|
|
|
free(tmp_buf);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ((result == -1) || (!S_ISLNK(stat_buf.st_mode)))
|
|
|
|
if ((result == -1) || (!S_ISLNK(stat_buf.st_mode)))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fprintf(stderr, "Error: \"%s\" is not a link or a directory.\n", kde_tmp_dir);
|
|
|
|
fprintf(stderr, "Error: \"%s\" is not a link or a directory.\n", kde_tmp_dir.c_str());
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* kde_tmp_dir is a link. Check whether it points to a valid directory. */
|
|
|
|
/* kde_tmp_dir is a link. Check whether it points to a valid directory. */
|
|
|
|
result = readlink(kde_tmp_dir, tmp_buf, PATH_MAX);
|
|
|
|
ssize_t size = 2048;
|
|
|
|
|
|
|
|
tmp_buf = NULL;
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
|
|
|
size *= 2;
|
|
|
|
|
|
|
|
tmp_buf = (char *) realloc(tmp_buf, size);
|
|
|
|
|
|
|
|
if (!tmp_buf)
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
result = readlink(kde_tmp_dir.c_str(), tmp_buf, size - 1);
|
|
|
|
if (result == -1)
|
|
|
|
if (result == -1)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fprintf(stderr, "Error: \"%s\" could not be read.\n", kde_tmp_dir);
|
|
|
|
arts_warning("Error: \"%s\" could not be read.\n", kde_tmp_dir.c_str());
|
|
|
|
return 1;
|
|
|
|
free(tmp_buf);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} while(result == size - 1);
|
|
|
|
tmp_buf[result] = '\0';
|
|
|
|
tmp_buf[result] = '\0';
|
|
|
|
|
|
|
|
|
|
|
|
printf("Link points to \"%s\"\n", tmp_buf);
|
|
|
|
printf("Link points to \"%s\"\n", tmp_buf);
|
|
|
|
if (strncmp(tmp_buf, user_tmp_dir, strlen(user_tmp_dir)) != 0)
|
|
|
|
if (strncmp(tmp_buf, user_tmp_dir.c_str(), user_tmp_dir.length()) != 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
fprintf(stderr, "Error: \"%s\" points to \"%s\" instead of \"%s\".\n", kde_tmp_dir, tmp_buf, user_tmp_dir);
|
|
|
|
fprintf(stderr, "Error: \"%s\" points to \"%s\" instead of \"%s\".\n", kde_tmp_dir.c_str(), tmp_buf, user_tmp_dir.c_str());
|
|
|
|
unlink(kde_tmp_dir);
|
|
|
|
free(tmp_buf);
|
|
|
|
printf("Creating link %s.\n", kde_tmp_dir);
|
|
|
|
unlink(kde_tmp_dir.c_str());
|
|
|
|
result = create_link(kde_tmp_dir, user_tmp_dir);
|
|
|
|
printf("Creating link %s.\n", kde_tmp_dir.c_str());
|
|
|
|
|
|
|
|
result = create_link(kde_tmp_dir.c_str(), user_tmp_dir.c_str());
|
|
|
|
if (result == 0) return 0; /* Success */
|
|
|
|
if (result == 0) return 0; /* Success */
|
|
|
|
unlink(kde_tmp_dir);
|
|
|
|
unlink(kde_tmp_dir.c_str());
|
|
|
|
strncat(user_tmp_dir, "XXXXXX", PATH_MAX - strlen(user_tmp_dir));
|
|
|
|
user_tmp_dir += "XXXXXX";
|
|
|
|
mktemp(user_tmp_dir); /* We want a directory, not a file, so using mkstemp makes no sense and is wrong */
|
|
|
|
tmp_buf = strdup(user_tmp_dir.c_str());
|
|
|
|
return create_link(kde_tmp_dir, user_tmp_dir);
|
|
|
|
mktemp(tmp_buf); /* We want a directory, not a file, so using mkstemp makes no sense and is wrong */
|
|
|
|
return 1;
|
|
|
|
result = create_link(kde_tmp_dir.c_str(), tmp_buf);
|
|
|
|
|
|
|
|
free(tmp_buf);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
result = check_tmp_dir(tmp_buf);
|
|
|
|
result = check_tmp_dir(tmp_buf);
|
|
|
|
|
|
|
|
free(tmp_buf);
|
|
|
|
if (result == 0) return 0; /* Success */
|
|
|
|
if (result == 0) return 0; /* Success */
|
|
|
|
unlink(kde_tmp_dir);
|
|
|
|
unlink(kde_tmp_dir.c_str());
|
|
|
|
strncat(user_tmp_dir, "XXXXXX", PATH_MAX - strlen(user_tmp_dir));
|
|
|
|
user_tmp_dir += "XXXXXX";
|
|
|
|
mktemp(user_tmp_dir); /* We want a directory, not a file, so using mkstemp makes no sense and is wrong */
|
|
|
|
tmp_buf = strdup(user_tmp_dir.c_str());
|
|
|
|
return create_link(kde_tmp_dir, user_tmp_dir);
|
|
|
|
mktemp(tmp_buf); /* We want a directory, not a file, so using mkstemp makes no sense and is wrong */
|
|
|
|
|
|
|
|
result = create_link(kde_tmp_dir.c_str(), tmp_buf);
|
|
|
|
|
|
|
|
free(tmp_buf);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
string MCOPUtils::createFilePath(string name)
|
|
|
|
string MCOPUtils::createFilePath(string name)
|
|
|
@ -372,11 +381,7 @@ string MCOPUtils::createFilePath(string name)
|
|
|
|
if (!tmp || !tmp[0])
|
|
|
|
if (!tmp || !tmp[0])
|
|
|
|
tmp = "/tmp";
|
|
|
|
tmp = "/tmp";
|
|
|
|
|
|
|
|
|
|
|
|
char tmp_prefix[PATH_MAX+1];
|
|
|
|
build_link(string(tmp) + "/ksocket-", "/socket-");
|
|
|
|
strcpy(tmp_prefix, tmp);
|
|
|
|
|
|
|
|
strcat(tmp_prefix, "/ksocket-");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
build_link(tmp_prefix, "/socket-");
|
|
|
|
|
|
|
|
mcop_dir = locate_mcop_dir();
|
|
|
|
mcop_dir = locate_mcop_dir();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!mcop_dir)
|
|
|
|
if (!mcop_dir)
|
|
|
|