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:
parent
5f0d12c9d7
commit
064901801e
1 changed files with 15 additions and 23 deletions
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue