dont go changing the session file all the time, and so then dont need to unlink so we dont end up stalling when the same session is asked for more than once.

This commit is contained in:
Dana Jansens 2003-11-11 11:54:29 +00:00
parent 5f0d12c9d7
commit 064901801e

View file

@ -92,17 +92,10 @@ static void save_commands()
prop_res.vals[i].length = strlen(sm_argv[i]); prop_res.vals[i].length = strlen(sm_argv[i]);
} }
if (save_file) {
prop_res.vals[i].value = "--sm-save-file"; prop_res.vals[i].value = "--sm-save-file";
prop_res.vals[i++].length = strlen("--sm-save-file"); prop_res.vals[i++].length = strlen("--sm-save-file");
prop_res.vals[i].value = save_file; prop_res.vals[i].value = save_file;
prop_res.vals[i++].length = strlen(save_file); prop_res.vals[i++].length = strlen(save_file);
} else {
prop_res.vals[i].value = "--sm-client-id";
prop_res.vals[i++].length = strlen("--sm-client-id");
prop_res.vals[i].value = sm_id;
prop_res.vals[i++].length = strlen(sm_id);
}
props[0] = &prop_res; props[0] = &prop_res;
props[1] = &prop_cmd; props[1] = &prop_cmd;
@ -169,6 +162,17 @@ void session_startup(gint *argc, gchar ***argv)
if (save_file) if (save_file)
session_load(save_file); session_load(save_file);
else {
gchar *filename;
/* this algo is from metacity */
filename = g_strdup_printf("%d-%d-%u.obs",
(gint) time(NULL),
(gint) getpid(),
g_random_int());
save_file = g_build_filename(sm_sessions_path, filename, NULL);
g_free(filename);
}
sm_argc = *argc; sm_argc = *argc;
sm_argv = *argv; sm_argv = *argv;
@ -315,22 +319,10 @@ static void sm_shutdown_cancelled(SmcConn conn, SmPointer data)
static gboolean session_save() static gboolean session_save()
{ {
gchar *filename;
FILE *f; FILE *f;
GList *it; GList *it;
gboolean success = TRUE; gboolean success = TRUE;
if (save_file)
unlink(save_file);
/* this algo is from metacity */
filename = g_strdup_printf("%d-%d-%u.obs",
(gint) time(NULL),
(gint) getpid(),
g_random_int());
save_file = g_build_filename(sm_sessions_path, filename, NULL);
g_free(filename);
f = fopen(save_file, "w"); f = fopen(save_file, "w");
if (!f) { if (!f) {
success = FALSE; success = FALSE;